2014-03-17 21:53:43 +00:00
|
|
|
//========================================================================
|
2019-04-16 12:43:29 +00:00
|
|
|
// GLFW 3.4 Wayland - www.glfw.org
|
2014-03-17 21:53:43 +00:00
|
|
|
//------------------------------------------------------------------------
|
|
|
|
// Copyright (c) 2014 Jonas Ådahl <jadahl@gmail.com>
|
|
|
|
//
|
|
|
|
// This software is provided 'as-is', without any express or implied
|
|
|
|
// warranty. In no event will the authors be held liable for any damages
|
|
|
|
// arising from the use of this software.
|
|
|
|
//
|
|
|
|
// Permission is granted to anyone to use this software for any purpose,
|
|
|
|
// including commercial applications, and to alter it and redistribute it
|
|
|
|
// freely, subject to the following restrictions:
|
|
|
|
//
|
|
|
|
// 1. The origin of this software must not be misrepresented; you must not
|
|
|
|
// claim that you wrote the original software. If you use this software
|
|
|
|
// in a product, an acknowledgment in the product documentation would
|
|
|
|
// be appreciated but is not required.
|
|
|
|
//
|
|
|
|
// 2. Altered source versions must be plainly marked as such, and must not
|
|
|
|
// be misrepresented as being the original software.
|
|
|
|
//
|
|
|
|
// 3. This notice may not be removed or altered from any source
|
|
|
|
// distribution.
|
|
|
|
//
|
|
|
|
//========================================================================
|
2019-05-20 13:24:14 +00:00
|
|
|
// It is fine to use C99 in this file because it will not be built with VS
|
|
|
|
//========================================================================
|
2014-03-17 21:53:43 +00:00
|
|
|
|
|
|
|
#include "internal.h"
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <errno.h>
|
2019-03-04 16:31:14 +00:00
|
|
|
#include <math.h>
|
2014-03-17 21:53:43 +00:00
|
|
|
|
|
|
|
|
2018-09-29 19:01:03 +00:00
|
|
|
static void outputHandleGeometry(void* data,
|
|
|
|
struct wl_output* output,
|
|
|
|
int32_t x,
|
|
|
|
int32_t y,
|
|
|
|
int32_t physicalWidth,
|
|
|
|
int32_t physicalHeight,
|
|
|
|
int32_t subpixel,
|
|
|
|
const char* make,
|
|
|
|
const char* model,
|
|
|
|
int32_t transform)
|
2014-03-17 21:53:43 +00:00
|
|
|
{
|
|
|
|
struct _GLFWmonitor *monitor = data;
|
|
|
|
|
2014-03-19 15:20:32 +00:00
|
|
|
monitor->wl.x = x;
|
|
|
|
monitor->wl.y = y;
|
2014-03-17 21:53:43 +00:00
|
|
|
monitor->widthMM = physicalWidth;
|
|
|
|
monitor->heightMM = physicalHeight;
|
2016-10-11 01:40:16 +00:00
|
|
|
|
2021-05-13 15:32:31 +00:00
|
|
|
snprintf(monitor->name, sizeof(monitor->name), "%s %s", make, model);
|
2014-03-17 21:53:43 +00:00
|
|
|
}
|
|
|
|
|
2018-09-29 19:01:03 +00:00
|
|
|
static void outputHandleMode(void* data,
|
|
|
|
struct wl_output* output,
|
|
|
|
uint32_t flags,
|
|
|
|
int32_t width,
|
|
|
|
int32_t height,
|
|
|
|
int32_t refresh)
|
2014-03-17 21:53:43 +00:00
|
|
|
{
|
|
|
|
struct _GLFWmonitor *monitor = data;
|
2016-12-05 00:19:48 +00:00
|
|
|
GLFWvidmode mode;
|
|
|
|
|
|
|
|
mode.width = width;
|
|
|
|
mode.height = height;
|
|
|
|
mode.redBits = 8;
|
|
|
|
mode.greenBits = 8;
|
|
|
|
mode.blueBits = 8;
|
2019-03-04 16:31:14 +00:00
|
|
|
mode.refreshRate = (int) round(refresh / 1000.0);
|
2016-12-05 00:19:48 +00:00
|
|
|
|
|
|
|
monitor->modeCount++;
|
|
|
|
monitor->modes =
|
|
|
|
realloc(monitor->modes, monitor->modeCount * sizeof(GLFWvidmode));
|
|
|
|
monitor->modes[monitor->modeCount - 1] = mode;
|
|
|
|
|
|
|
|
if (flags & WL_OUTPUT_MODE_CURRENT)
|
|
|
|
monitor->wl.currentMode = monitor->modeCount - 1;
|
2014-03-17 21:53:43 +00:00
|
|
|
}
|
|
|
|
|
2018-09-29 19:01:03 +00:00
|
|
|
static void outputHandleDone(void* data, struct wl_output* output)
|
2014-03-17 21:53:43 +00:00
|
|
|
{
|
|
|
|
struct _GLFWmonitor *monitor = data;
|
|
|
|
|
2021-02-09 20:33:23 +00:00
|
|
|
if (monitor->widthMM <= 0 || monitor->heightMM <= 0)
|
|
|
|
{
|
|
|
|
// If Wayland does not provide a physical size, assume the default 96 DPI
|
|
|
|
const GLFWvidmode* mode = &monitor->modes[monitor->wl.currentMode];
|
|
|
|
monitor->widthMM = (int) (mode->width * 25.4f / 96.f);
|
|
|
|
monitor->heightMM = (int) (mode->height * 25.4f / 96.f);
|
|
|
|
}
|
|
|
|
|
2016-12-05 00:19:48 +00:00
|
|
|
_glfwInputMonitor(monitor, GLFW_CONNECTED, _GLFW_INSERT_LAST);
|
2014-03-17 21:53:43 +00:00
|
|
|
}
|
|
|
|
|
2018-09-29 19:01:03 +00:00
|
|
|
static void outputHandleScale(void* data,
|
|
|
|
struct wl_output* output,
|
|
|
|
int32_t factor)
|
2014-03-17 21:53:43 +00:00
|
|
|
{
|
2015-10-10 15:35:06 +00:00
|
|
|
struct _GLFWmonitor *monitor = data;
|
|
|
|
|
|
|
|
monitor->wl.scale = factor;
|
2014-03-17 21:53:43 +00:00
|
|
|
}
|
|
|
|
|
2016-10-01 19:05:29 +00:00
|
|
|
static const struct wl_output_listener outputListener = {
|
2018-09-29 19:01:03 +00:00
|
|
|
outputHandleGeometry,
|
|
|
|
outputHandleMode,
|
|
|
|
outputHandleDone,
|
|
|
|
outputHandleScale,
|
2014-03-17 21:53:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
////// GLFW internal API //////
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2015-12-03 17:16:46 +00:00
|
|
|
void _glfwAddOutputWayland(uint32_t name, uint32_t version)
|
2014-03-17 21:53:43 +00:00
|
|
|
{
|
|
|
|
_GLFWmonitor *monitor;
|
|
|
|
struct wl_output *output;
|
|
|
|
|
|
|
|
if (version < 2)
|
|
|
|
{
|
|
|
|
_glfwInputError(GLFW_PLATFORM_ERROR,
|
2014-03-19 15:32:50 +00:00
|
|
|
"Wayland: Unsupported output interface version");
|
2014-03-17 21:53:43 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-10-11 01:40:16 +00:00
|
|
|
// The actual name of this output will be set in the geometry handler.
|
2021-05-13 15:32:31 +00:00
|
|
|
monitor = _glfwAllocMonitor("", 0, 0);
|
2014-03-17 21:53:43 +00:00
|
|
|
|
2014-03-19 15:20:32 +00:00
|
|
|
output = wl_registry_bind(_glfw.wl.registry,
|
2014-03-17 21:53:43 +00:00
|
|
|
name,
|
|
|
|
&wl_output_interface,
|
|
|
|
2);
|
|
|
|
if (!output)
|
|
|
|
{
|
|
|
|
_glfwFreeMonitor(monitor);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-10-10 15:35:06 +00:00
|
|
|
monitor->wl.scale = 1;
|
2014-03-19 15:20:32 +00:00
|
|
|
monitor->wl.output = output;
|
2018-02-24 21:18:39 +00:00
|
|
|
monitor->wl.name = name;
|
2014-03-17 21:53:43 +00:00
|
|
|
|
2016-12-05 00:19:48 +00:00
|
|
|
wl_output_add_listener(output, &outputListener, monitor);
|
2014-03-17 21:53:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
////// GLFW platform API //////
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2018-02-24 20:53:39 +00:00
|
|
|
void _glfwPlatformFreeMonitor(_GLFWmonitor* monitor)
|
|
|
|
{
|
|
|
|
if (monitor->wl.output)
|
|
|
|
wl_output_destroy(monitor->wl.output);
|
|
|
|
}
|
|
|
|
|
2014-03-17 21:53:43 +00:00
|
|
|
void _glfwPlatformGetMonitorPos(_GLFWmonitor* monitor, int* xpos, int* ypos)
|
|
|
|
{
|
|
|
|
if (xpos)
|
2014-03-19 15:20:32 +00:00
|
|
|
*xpos = monitor->wl.x;
|
2014-03-17 21:53:43 +00:00
|
|
|
if (ypos)
|
2014-03-19 15:20:32 +00:00
|
|
|
*ypos = monitor->wl.y;
|
2014-03-17 21:53:43 +00:00
|
|
|
}
|
|
|
|
|
2017-08-29 17:19:00 +00:00
|
|
|
void _glfwPlatformGetMonitorContentScale(_GLFWmonitor* monitor,
|
|
|
|
float* xscale, float* yscale)
|
|
|
|
{
|
|
|
|
if (xscale)
|
|
|
|
*xscale = (float) monitor->wl.scale;
|
|
|
|
if (yscale)
|
|
|
|
*yscale = (float) monitor->wl.scale;
|
|
|
|
}
|
|
|
|
|
2019-02-25 13:01:08 +00:00
|
|
|
void _glfwPlatformGetMonitorWorkarea(_GLFWmonitor* monitor,
|
|
|
|
int* xpos, int* ypos,
|
|
|
|
int* width, int* height)
|
2018-09-08 16:01:28 +00:00
|
|
|
{
|
|
|
|
if (xpos)
|
|
|
|
*xpos = monitor->wl.x;
|
|
|
|
if (ypos)
|
|
|
|
*ypos = monitor->wl.y;
|
|
|
|
if (width)
|
|
|
|
*width = monitor->modes[monitor->wl.currentMode].width;
|
|
|
|
if (height)
|
|
|
|
*height = monitor->modes[monitor->wl.currentMode].height;
|
|
|
|
}
|
|
|
|
|
2014-03-17 21:53:43 +00:00
|
|
|
GLFWvidmode* _glfwPlatformGetVideoModes(_GLFWmonitor* monitor, int* found)
|
|
|
|
{
|
2016-12-05 00:19:48 +00:00
|
|
|
*found = monitor->modeCount;
|
|
|
|
return monitor->modes;
|
2014-03-17 21:53:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void _glfwPlatformGetVideoMode(_GLFWmonitor* monitor, GLFWvidmode* mode)
|
|
|
|
{
|
2016-12-05 00:19:48 +00:00
|
|
|
*mode = monitor->modes[monitor->wl.currentMode];
|
2014-03-17 21:53:43 +00:00
|
|
|
}
|
2014-03-19 15:11:19 +00:00
|
|
|
|
2018-12-19 13:53:01 +00:00
|
|
|
GLFWbool _glfwPlatformGetGammaRamp(_GLFWmonitor* monitor, GLFWgammaramp* ramp)
|
2014-08-18 10:31:48 +00:00
|
|
|
{
|
2020-05-20 16:02:58 +00:00
|
|
|
_glfwInputError(GLFW_FEATURE_UNAVAILABLE,
|
2019-06-07 22:06:22 +00:00
|
|
|
"Wayland: Gamma ramp access is not available");
|
2018-12-19 13:53:01 +00:00
|
|
|
return GLFW_FALSE;
|
2014-08-18 10:31:48 +00:00
|
|
|
}
|
|
|
|
|
2018-09-29 16:11:11 +00:00
|
|
|
void _glfwPlatformSetGammaRamp(_GLFWmonitor* monitor,
|
|
|
|
const GLFWgammaramp* ramp)
|
2014-08-18 10:31:48 +00:00
|
|
|
{
|
2020-05-20 16:02:58 +00:00
|
|
|
_glfwInputError(GLFW_FEATURE_UNAVAILABLE,
|
2018-11-24 15:25:20 +00:00
|
|
|
"Wayland: Gamma ramp access is not available");
|
2014-08-18 10:31:48 +00:00
|
|
|
}
|
|
|
|
|
2015-08-16 20:02:31 +00:00
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
////// GLFW native API //////
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
GLFWAPI struct wl_output* glfwGetWaylandMonitor(GLFWmonitor* handle)
|
|
|
|
{
|
|
|
|
_GLFWmonitor* monitor = (_GLFWmonitor*) handle;
|
|
|
|
_GLFW_REQUIRE_INIT_OR_RETURN(NULL);
|
|
|
|
return monitor->wl.output;
|
|
|
|
}
|
|
|
|
|