2011-05-07 08:53:50 +00:00
|
|
|
//========================================================================
|
|
|
|
// GLFW - An OpenGL library
|
|
|
|
// Platform: X11 (Unix)
|
|
|
|
// API version: 3.0
|
|
|
|
// WWW: http://www.glfw.org/
|
|
|
|
//------------------------------------------------------------------------
|
|
|
|
// Copyright (c) 2002-2006 Marcus Geelnard
|
|
|
|
// Copyright (c) 2006-2010 Camilla Berglund <elmindreda@elmindreda.org>
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
//
|
|
|
|
//========================================================================
|
|
|
|
|
|
|
|
#include "internal.h"
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
////// GLFW platform API //////
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2011-10-06 21:28:56 +00:00
|
|
|
_GLFWmonitor** _glfwCreateMonitor(_GLFWmonitor** current,
|
|
|
|
XRROutputInfo* outputInfo,
|
|
|
|
XRRCrtcInfo* crtcInfo)
|
2011-05-07 08:53:50 +00:00
|
|
|
{
|
2011-10-03 07:24:35 +00:00
|
|
|
*current = _glfwMalloc(sizeof(_GLFWmonitor));
|
|
|
|
memset(*current, 0, sizeof(_GLFWmonitor));
|
2011-05-07 08:53:50 +00:00
|
|
|
|
|
|
|
(*current)->physicalWidth = outputInfo->mm_width;
|
|
|
|
(*current)->physicalHeight = outputInfo->mm_height;
|
|
|
|
|
2011-10-06 21:28:56 +00:00
|
|
|
(*current)->name = _glfwMalloc(strlen(outputInfo->name) + 1);
|
|
|
|
memcpy((*current)->name, outputInfo->name, strlen(outputInfo->name) + 1);
|
|
|
|
(*current)->name[strlen(outputInfo->name)] = '\0';
|
2011-05-07 08:53:50 +00:00
|
|
|
|
2011-10-06 21:28:56 +00:00
|
|
|
(*current)->screenX = crtcInfo->x;
|
|
|
|
(*current)->screenY = crtcInfo->y;
|
2011-10-02 20:13:47 +00:00
|
|
|
|
|
|
|
(*current)->X11.output = outputInfo;
|
2011-05-07 08:53:50 +00:00
|
|
|
return &((*current)->next);
|
|
|
|
}
|
|
|
|
|
2011-10-03 07:24:35 +00:00
|
|
|
_GLFWmonitor* _glfwDestroyMonitor(_GLFWmonitor* monitor)
|
2011-05-07 08:53:50 +00:00
|
|
|
{
|
2011-10-03 07:24:35 +00:00
|
|
|
_GLFWmonitor* result;
|
2011-05-07 08:53:50 +00:00
|
|
|
|
2011-10-03 07:24:35 +00:00
|
|
|
result = monitor->next;
|
2011-05-07 08:53:50 +00:00
|
|
|
|
2011-10-03 16:48:59 +00:00
|
|
|
#if defined (_GLFW_HAS_XRANDR)
|
2011-10-06 21:28:56 +00:00
|
|
|
XRRFreeOutputInfo(monitor->X11.output);
|
2011-10-03 16:48:59 +00:00
|
|
|
#endif /*_GLFW_HAS_XRANDR*/
|
2011-10-02 20:13:47 +00:00
|
|
|
|
2011-10-06 21:28:56 +00:00
|
|
|
_glfwFree(monitor->name);
|
2011-10-03 07:24:35 +00:00
|
|
|
_glfwFree(monitor);
|
2011-05-07 08:53:50 +00:00
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2011-10-03 07:24:35 +00:00
|
|
|
void _glfwInitMonitors(void)
|
2011-05-07 08:53:50 +00:00
|
|
|
{
|
2011-10-03 16:48:59 +00:00
|
|
|
_glfwLibrary.monitorListHead = NULL;
|
|
|
|
|
2011-10-06 21:28:56 +00:00
|
|
|
if (_glfwLibrary.X11.RandR.available)
|
2011-05-07 08:53:50 +00:00
|
|
|
{
|
2011-10-03 16:48:59 +00:00
|
|
|
#if defined (_GLFW_HAS_XRANDR)
|
2011-05-07 08:53:50 +00:00
|
|
|
XRRScreenResources* resources;
|
|
|
|
int outputIDX;
|
2011-10-03 07:24:35 +00:00
|
|
|
_GLFWmonitor** curMonitor;
|
2011-05-07 08:53:50 +00:00
|
|
|
|
2011-10-03 07:24:35 +00:00
|
|
|
curMonitor = &_glfwLibrary.monitorListHead;
|
2011-05-07 08:53:50 +00:00
|
|
|
|
|
|
|
resources = XRRGetScreenResources(_glfwLibrary.X11.display,
|
|
|
|
_glfwLibrary.X11.root);
|
|
|
|
|
2011-10-06 21:28:56 +00:00
|
|
|
for (outputIDX = 0; outputIDX < resources->noutput; outputIDX++)
|
2011-05-07 08:53:50 +00:00
|
|
|
{
|
|
|
|
// physical device
|
|
|
|
XRROutputInfo* outputInfo = NULL;
|
|
|
|
// logical surface
|
|
|
|
XRRCrtcInfo* crtcInfo = NULL;
|
|
|
|
int crtcIDX;
|
|
|
|
|
|
|
|
outputInfo = XRRGetOutputInfo(_glfwLibrary.X11.display,
|
|
|
|
resources,
|
|
|
|
resources->outputs[outputIDX]);
|
|
|
|
|
2011-10-06 21:28:56 +00:00
|
|
|
if (outputInfo->connection == RR_Connected)
|
2011-05-07 08:53:50 +00:00
|
|
|
{
|
2011-10-06 21:28:56 +00:00
|
|
|
for (crtcIDX = 0; crtcIDX < outputInfo->ncrtc; crtcIDX++)
|
2011-05-07 08:53:50 +00:00
|
|
|
{
|
2011-10-06 21:28:56 +00:00
|
|
|
if (outputInfo->crtc == outputInfo->crtcs[crtcIDX])
|
2011-05-07 08:53:50 +00:00
|
|
|
{
|
|
|
|
crtcInfo = XRRGetCrtcInfo(_glfwLibrary.X11.display,
|
|
|
|
resources,
|
|
|
|
outputInfo->crtcs[crtcIDX]);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-10-03 07:24:35 +00:00
|
|
|
curMonitor = _glfwCreateMonitor(curMonitor, outputInfo, crtcInfo);
|
2011-05-07 08:53:50 +00:00
|
|
|
|
2011-10-03 07:24:35 +00:00
|
|
|
// Freeing of the outputInfo is done in _glfwDestroyMonitor
|
2011-05-07 08:53:50 +00:00
|
|
|
XRRFreeCrtcInfo(crtcInfo);
|
|
|
|
}
|
|
|
|
}
|
2011-10-03 16:48:59 +00:00
|
|
|
#endif /*_GLFW_HAS_XRANDR*/
|
2011-05-07 08:53:50 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-10-03 07:24:35 +00:00
|
|
|
void _glfwTerminateMonitors(void)
|
2011-05-07 08:53:50 +00:00
|
|
|
{
|
2011-10-06 21:28:56 +00:00
|
|
|
while (_glfwLibrary.monitorListHead)
|
2011-10-03 07:24:35 +00:00
|
|
|
_glfwLibrary.monitorListHead = _glfwDestroyMonitor(_glfwLibrary.monitorListHead);
|
2011-05-07 08:53:50 +00:00
|
|
|
}
|
|
|
|
|