mirror of
https://github.com/glfw/glfw.git
synced 2024-11-29 23:54:37 +00:00
Set up the Mir connection.
Set up the first of the Mir surface.
This commit is contained in:
parent
46c9663ed7
commit
4295b77582
@ -6,11 +6,26 @@
|
|||||||
|
|
||||||
int _glfwPlatformInit(void)
|
int _glfwPlatformInit(void)
|
||||||
{
|
{
|
||||||
return 0;
|
_glfw.mir.connection = mir_connect_sync(NULL, __PRETTY_FUNCTION__);
|
||||||
|
|
||||||
|
if (!mir_connection_is_valid(_glfw.mir.connection))
|
||||||
|
{
|
||||||
|
_glfwInputError(GLFW_PLATFORM_ERROR,
|
||||||
|
"Mir: Unable to connect to Server\n");
|
||||||
|
return GL_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
_glfw.mir.native_display = mir_connection_get_egl_native_display(_glfw.mir.connection);
|
||||||
|
|
||||||
|
// TODO Add in bits to get the correct monitors and screen sizes...
|
||||||
|
// Ill just hard code in my own right now to jump ahead to surface and events.
|
||||||
|
|
||||||
|
return GL_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void _glfwPlatformTerminate(void)
|
void _glfwPlatformTerminate(void)
|
||||||
{
|
{
|
||||||
|
mir_connection_release(_glfw.mir.connection);
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* _glfwPlatformGetVersionString(void)
|
const char* _glfwPlatformGetVersionString(void)
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
////// GLFW platform API //////
|
////// GLFW platform API //////
|
||||||
@ -8,7 +9,10 @@
|
|||||||
|
|
||||||
_GLFWmonitor** _glfwPlatformGetMonitors(int* count)
|
_GLFWmonitor** _glfwPlatformGetMonitors(int* count)
|
||||||
{
|
{
|
||||||
return NULL;
|
// FIXME Work out the best way to get this from mir, as we'll end up looping
|
||||||
|
// through all of that info... best to store it before we get here.
|
||||||
|
_GLFWmonitor** monitors = calloc(1, sizeof(_GLFWmonitor*));
|
||||||
|
return monitors;
|
||||||
}
|
}
|
||||||
|
|
||||||
GLboolean _glfwPlatformIsSameMonitor(_GLFWmonitor* first, _GLFWmonitor* second)
|
GLboolean _glfwPlatformIsSameMonitor(_GLFWmonitor* first, _GLFWmonitor* second)
|
||||||
|
@ -13,8 +13,8 @@
|
|||||||
#error "The Mir backend depends on EGL platform support"
|
#error "The Mir backend depends on EGL platform support"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define _GLFW_EGL_NATIVE_WINDOW NULL
|
#define _GLFW_EGL_NATIVE_WINDOW window->mir.native_window
|
||||||
#define _GLFW_EGL_NATIVE_DISPLAY NULL
|
#define _GLFW_EGL_NATIVE_DISPLAY _glfw.mir.native_display
|
||||||
|
|
||||||
#define _GLFW_PLATFORM_WINDOW_STATE _GLFWwindowMir mir;
|
#define _GLFW_PLATFORM_WINDOW_STATE _GLFWwindowMir mir;
|
||||||
#define _GLFW_PLATFORM_MONITOR_STATE _GLFWmonitorMir mir;
|
#define _GLFW_PLATFORM_MONITOR_STATE _GLFWmonitorMir mir;
|
||||||
@ -23,6 +23,11 @@
|
|||||||
|
|
||||||
typedef struct _GLFWwindowMir
|
typedef struct _GLFWwindowMir
|
||||||
{
|
{
|
||||||
|
MirSurface* surface;
|
||||||
|
|
||||||
|
EGLSurface egl_surface;
|
||||||
|
MirEGLNativeWindowType native_window;
|
||||||
|
|
||||||
} _GLFWwindowMir;
|
} _GLFWwindowMir;
|
||||||
|
|
||||||
typedef struct _GLFWmonitorMir
|
typedef struct _GLFWmonitorMir
|
||||||
@ -33,6 +38,9 @@ typedef struct _GLFWlibraryMir
|
|||||||
{
|
{
|
||||||
MirConnection* connection;
|
MirConnection* connection;
|
||||||
|
|
||||||
|
MirEGLNativeDisplayType native_display;
|
||||||
|
|
||||||
|
|
||||||
} _GLFWlibraryMir;
|
} _GLFWlibraryMir;
|
||||||
|
|
||||||
typedef struct _GLFWcursorMir
|
typedef struct _GLFWcursorMir
|
||||||
|
@ -1,5 +1,31 @@
|
|||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
|
|
||||||
|
MirPixelFormat FindValidPixelFormat()
|
||||||
|
{
|
||||||
|
unsigned int pf_size = 32;
|
||||||
|
unsigned int valid_formats;
|
||||||
|
unsigned int f;
|
||||||
|
|
||||||
|
MirPixelFormat formats[pf_size];
|
||||||
|
mir_connection_get_available_surface_formats(_glfw.mir.connection, formats,
|
||||||
|
pf_size, &valid_formats);
|
||||||
|
|
||||||
|
for (f = 0; f < valid_formats; f++)
|
||||||
|
{
|
||||||
|
MirPixelFormat cur_pf = formats[f];
|
||||||
|
|
||||||
|
if (cur_pf == mir_pixel_format_abgr_8888 ||
|
||||||
|
cur_pf == mir_pixel_format_xbgr_8888 ||
|
||||||
|
cur_pf == mir_pixel_format_argb_8888 ||
|
||||||
|
cur_pf == mir_pixel_format_xrgb_8888)
|
||||||
|
{
|
||||||
|
return cur_pf;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return mir_pixel_format_invalid;
|
||||||
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
////// GLFW platform API //////
|
////// GLFW platform API //////
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
@ -9,7 +35,48 @@ int _glfwPlatformCreateWindow(_GLFWwindow* window,
|
|||||||
const _GLFWctxconfig* ctxconfig,
|
const _GLFWctxconfig* ctxconfig,
|
||||||
const _GLFWfbconfig* fbconfig)
|
const _GLFWfbconfig* fbconfig)
|
||||||
{
|
{
|
||||||
return 0;
|
if (!_glfwCreateContext(window, ctxconfig, fbconfig))
|
||||||
|
return GL_FALSE;
|
||||||
|
|
||||||
|
MirSurfaceParameters params =
|
||||||
|
{
|
||||||
|
.name = "MirSurface",
|
||||||
|
.width = 1600,
|
||||||
|
.height = 900,
|
||||||
|
.pixel_format = mir_pixel_format_invalid,
|
||||||
|
.buffer_usage = mir_buffer_usage_hardware,
|
||||||
|
.output_id = mir_display_output_id_invalid
|
||||||
|
};
|
||||||
|
|
||||||
|
/* // Add the HandleInput function somewhere... to handle events from the windows
|
||||||
|
MirEventDelegate delegate =
|
||||||
|
{
|
||||||
|
HandleInput,
|
||||||
|
NULL
|
||||||
|
};
|
||||||
|
|
||||||
|
mir_surface_set_event_handler(window->mir.surface, &delegate);
|
||||||
|
*/
|
||||||
|
|
||||||
|
params.pixel_format = FindValidPixelFormat();
|
||||||
|
if (params.pixel_format == mir_pixel_format_invalid)
|
||||||
|
{
|
||||||
|
_glfwInputError(GLFW_PLATFORM_ERROR,
|
||||||
|
"Mir: Unable to find a correct pixel format!\n");
|
||||||
|
return GL_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
window->mir.surface = mir_connection_create_surface_sync(_glfw.mir.connection, ¶ms);
|
||||||
|
if (!mir_surface_is_valid(window->mir.surface))
|
||||||
|
{
|
||||||
|
_glfwInputError(GLFW_PLATFORM_ERROR,
|
||||||
|
"Mir: Unable to create surface!\n");
|
||||||
|
return GL_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
window->mir.native_window = mir_surface_get_egl_native_window(window->mir.surface);
|
||||||
|
|
||||||
|
return GL_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void _glfwPlatformDestroyWindow(_GLFWwindow* window)
|
void _glfwPlatformDestroyWindow(_GLFWwindow* window)
|
||||||
|
Loading…
Reference in New Issue
Block a user