Merge pull request #30 from Jonanin/master

Fixed build errors on Visual C++.
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 5838b1c..96f322f 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -30,6 +30,9 @@
     find_package(OpenGL REQUIRED)
 endif()
 
+set(CMAKE_THREAD_PREFER_PTHREAD OFF)
+find_package(Threads REQUIRED)
+
 #--------------------------------------------------------------------
 # Enable all warnings on GCC, regardless of OS
 #--------------------------------------------------------------------
@@ -239,39 +242,8 @@
 
     set(CMAKE_REQUIRED_LIBRARIES ${EGL_LIBRARY})
 
-    if (_GLFW_X11)
+    if (UNIX)
         set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} egl")
-
-        include(CheckFunctionExists)
-
-        check_function_exists(eglGetProcAddress _GLFW_HAS_EGLGETPROCADDRESS)
-
-        if (NOT _GLFW_HAS_EGLGETPROCADDRESS)
-            message(WARNING "No eglGetProcAddress found")
-
-            # Check for dlopen support as a fallback
-
-            find_library(DL_LIBRARY dl)
-            mark_as_advanced(DL_LIBRARY)
-            if (DL_LIBRARY)
-                set(CMAKE_REQUIRED_LIBRARIES ${DL_LIBRARY})
-            else()
-                set(CMAKE_REQUIRED_LIBRARIES "")
-            endif()
-
-            check_function_exists(dlopen _GLFW_HAS_DLOPEN)
-
-            if (NOT _GLFW_HAS_DLOPEN)
-                message(FATAL_ERROR "No entry point retrieval mechanism found")
-            endif()
-
-            if (DL_LIBRARY)
-                list(APPEND glfw_LIBRARIES ${DL_LIBRARY})
-                set(GLFW_PKG_LIBS "${GLFW_PKG_LIBS} -ldl")
-            endif()
-        endif()
-    elseif (_GLFW_WIN32)
-        set(_GLFW_HAS_EGLGETPROCADDRESS 1)
     endif()
 
 endif()
diff --git a/src/config.h.in b/src/config.h.in
index d391fcd..61178f9 100644
--- a/src/config.h.in
+++ b/src/config.h.in
@@ -72,9 +72,6 @@
 // Define this to 1 if glXGetProcAddressEXT is available
 #cmakedefine _GLFW_HAS_GLXGETPROCADDRESSEXT
 
-// Define this to 1 if eglGetProcAddress is available
-#cmakedefine _GLFW_HAS_EGLGETPROCADDRESS
-
 // The GLFW version as used by glfwGetVersionString
 #define _GLFW_VERSION_FULL "@GLFW_VERSION_FULL@"
 
diff --git a/src/egl_context.c b/src/egl_context.c
index fc41f2c..eb2815f 100644
--- a/src/egl_context.c
+++ b/src/egl_context.c
@@ -361,31 +361,6 @@
 
 int _glfwInitOpenGL(void)
 {
-#if defined(_GLFW_DLOPEN_LIBEGL)
-    int i;
-    char* libEGL_names[ ] =
-    {
-        "libEGL.so",
-        "libEGL.so.1",
-        "/usr/lib/libEGL.so",
-        "/usr/lib/libEGL.so.1",
-        NULL
-    };
-
-    for (i = 0;  libEGL_names[i] != NULL;  i++)
-    {
-        _glfw.egl.libEGL = dlopen(libEGL_names[i], RTLD_LAZY | RTLD_GLOBAL);
-        if (_glfw.egl.libEGL)
-            break;
-    }
-
-    if (!_glfw.egl.libEGL)
-    {
-        _glfwInputError(GLFW_PLATFORM_ERROR, "EGL: Failed to find libEGL");
-        return GL_FALSE;
-    }
-#endif
-
     _glfw.egl.display = eglGetDisplay(_GLFW_EGL_NATIVE_DISPLAY);
     if (_glfw.egl.display == EGL_NO_DISPLAY)
     {
@@ -414,14 +389,6 @@
 
 void _glfwTerminateOpenGL(void)
 {
-#if defined(_GLFW_DLOPEN_LIBEGL)
-    if (_glfw.egl.libEGL != NULL)
-    {
-        dlclose(_glfw.egl.libEGL);
-        _glfw.egl.libEGL = NULL;
-    }
-#endif
-
     eglTerminate(_glfw.egl.display);
 }
 
@@ -603,6 +570,6 @@
 
 GLFWglproc _glfwPlatformGetProcAddress(const char* procname)
 {
-    return _glfw_eglGetProcAddress(procname);
+    return eglGetProcAddress(procname);
 }
 
diff --git a/src/egl_platform.h b/src/egl_platform.h
index 6eeb9e5..065b49f 100644
--- a/src/egl_platform.h
+++ b/src/egl_platform.h
@@ -43,17 +43,6 @@
  #include <dlfcn.h>
 #endif
 
-// We support two different ways for getting addresses for EGL
-// extension functions: eglGetProcAddress and dlsym
-#if defined(_GLFW_HAS_EGLGETPROCADDRESS)
- #define _glfw_eglGetProcAddress(x) eglGetProcAddress(x)
-#elif defined(_GLFW_HAS_DLOPEN)
- #define _glfw_eglGetProcAddress(x) dlsym(_glfw.egl.libEGL, x)
- #define _GLFW_DLOPEN_LIBEGL
-#else
- #error "No OpenGL entry point retrieval mechanism was enabled"
-#endif
-
 #define _GLFW_PLATFORM_CONTEXT_STATE        _GLFWcontextEGL egl
 #define _GLFW_PLATFORM_LIBRARY_OPENGL_STATE _GLFWlibraryEGL egl
 
@@ -87,9 +76,6 @@
 
     GLboolean       KHR_create_context;
 
-#if defined(_GLFW_DLOPEN_LIBEGL)
-    void*           libEGL;  // dlopen handle for libEGL.so
-#endif
 } _GLFWlibraryEGL;
 
 
diff --git a/src/win32_window.c b/src/win32_window.c
index 40f9913..688d555 100644
--- a/src/win32_window.c
+++ b/src/win32_window.c
@@ -715,47 +715,29 @@
                         const _GLFWwndconfig* wndconfig,
                         const _GLFWfbconfig* fbconfig)
 {
-    DWORD dwStyle, dwExStyle;
     int positionX, positionY, fullWidth, fullHeight;
     POINT pos;
     WCHAR* wideTitle;
 
-    // Set common window styles
-    dwStyle = WS_CLIPSIBLINGS | WS_CLIPCHILDREN;
-    dwExStyle = WS_EX_APPWINDOW;
+    // Set window styles common to all window modes
+    window->win32.dwStyle = WS_CLIPSIBLINGS | WS_CLIPCHILDREN;
+    window->win32.dwExStyle = WS_EX_APPWINDOW;
 
-    // Set window style, depending on fullscreen mode
+    // Add mode-dependent window styles
     if (window->monitor)
-    {
-        dwStyle |= WS_POPUP;
-
-        // Here's a trick for helping us getting window focus
-        // (SetForegroundWindow doesn't work properly under
-        // Win98/ME/2K/.NET/+)
-        /*
-        if (_glfw.Sys.WinVer != _GLFW_WIN_95 &&
-            _glfw.Sys.WinVer != _GLFW_WIN_NT4 &&
-            _glfw.Sys.WinVer != _GLFW_WIN_XP)
-        {
-            dwStyle |= WS_MINIMIZE;
-        }
-        */
-    }
+        window->win32.dwStyle |= WS_POPUP;
     else
     {
-        dwStyle |= WS_OVERLAPPED | WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX;
+        window->win32.dwStyle |= WS_OVERLAPPED | WS_CAPTION |
+                                 WS_SYSMENU | WS_MINIMIZEBOX;
 
         if (wndconfig->resizable)
         {
-            dwStyle |= (WS_MAXIMIZEBOX | WS_SIZEBOX);
-            dwExStyle |= WS_EX_WINDOWEDGE;
+            window->win32.dwStyle |= WS_MAXIMIZEBOX | WS_SIZEBOX;
+            window->win32.dwExStyle |= WS_EX_WINDOWEDGE;
         }
     }
 
-    // Remember window styles (used by getFullWindowSize)
-    window->win32.dwStyle   = dwStyle;
-    window->win32.dwExStyle = dwExStyle;
-
     // Adjust window size for frame and title bar
     getFullWindowSize(window, window->width, window->height, &fullWidth, &fullHeight);
 
diff --git a/src/window.c b/src/window.c
index cc2f559..124e7e4 100644
--- a/src/window.c
+++ b/src/window.c
@@ -221,8 +221,11 @@
         return NULL;
     }
 
-    // We need to copy these values before doing anything that can fail, as the
-    // window hints should be cleared after each call even if it fails
+    if (width <= 0 || height <= 0)
+    {
+        _glfwInputError(GLFW_INVALID_VALUE, "Invalid window size");
+        return GL_FALSE;
+    }
 
     // Set up desired framebuffer config
     fbconfig.redBits        = Max(_glfw.hints.redBits, 0);
@@ -260,15 +263,6 @@
     if (!_glfwIsValidContextConfig(&wndconfig))
         return GL_FALSE;
 
-    // Save the currently current context so it can be restored later
-    previous = glfwGetCurrentContext();
-
-    if (width <= 0 || height <= 0)
-    {
-        _glfwInputError(GLFW_INVALID_VALUE, "Invalid window size");
-        return GL_FALSE;
-    }
-
     window = (_GLFWwindow*) calloc(1, sizeof(_GLFWwindow));
     if (!window)
     {
@@ -295,6 +289,9 @@
         window->videoMode.blueBits  = fbconfig.blueBits;
     }
 
+    // Save the currently current context so it can be restored later
+    previous = glfwGetCurrentContext();
+
     // Open the actual window and create its context
     if (!_glfwPlatformCreateWindow(window, &wndconfig, &fbconfig))
     {
diff --git a/src/x11_init.c b/src/x11_init.c
index cffbc7c..72fc90a 100644
--- a/src/x11_init.c
+++ b/src/x11_init.c
@@ -395,7 +395,7 @@
 // Check whether the running window manager is EWMH-compliant
 //========================================================================
 
-static void initEWMH(void)
+static void detectEWMH(void)
 {
     Window* windowFromRoot = NULL;
     Window* windowFromChild = NULL;
@@ -549,6 +549,9 @@
     // the keyboard mapping.
     updateKeyCodeLUT();
 
+    // Detect whether an EWMH-conformant window manager is running
+    detectEWMH();
+
     // Find or create selection property atom
     _glfw.x11.selection.property =
         XInternAtom(_glfw.x11.display, "GLFW_SELECTION", False);
@@ -638,14 +641,11 @@
     if (!_glfwInitOpenGL())
         return GL_FALSE;
 
-    initEWMH();
-
     _glfw.x11.cursor = createNULLCursor();
 
     if (!_glfwInitJoysticks())
         return GL_FALSE;
 
-    // Start the timer
     _glfwInitTimer();
 
     return GL_TRUE;
@@ -672,7 +672,6 @@
 
     terminateDisplay();
 
-    // Free clipboard memory
     if (_glfw.x11.selection.string)
         free(_glfw.x11.selection.string);
 }
@@ -708,12 +707,8 @@
         " glXGetProcAddressARB"
 #elif defined(_GLFW_HAS_GLXGETPROCADDRESSEXT)
         " glXGetProcAddressEXT"
-#elif defined(_GLFW_HAS_EGLGETPROCADDRESS)
-        " eglGetProcAddress"
 #elif defined(_GLFW_DLOPEN_LIBGL)
         " dlsym(libGL)"
-#elif defined(_GLFW_DLOPEN_LIBEGL)
-        " dlsym(libEGL)"
 #else
         " no-extension-support"
 #endif
diff --git a/src/x11_platform.h b/src/x11_platform.h
index 1ffb0e1..a1e5198 100644
--- a/src/x11_platform.h
+++ b/src/x11_platform.h
@@ -124,7 +124,9 @@
     Display*        display;
     int             screen;
     Window          root;
-    Cursor          cursor;   // Invisible cursor for hidden cursor
+
+    // Invisible cursor for hidden cursor mode
+    Cursor          cursor;
 
     Atom            wmDeleteWindow;    // WM_DELETE_WINDOW atom
     Atom            wmName;            // _NET_WM_NAME atom
@@ -161,10 +163,9 @@
         int         versionMinor;
     } xkb;
 
-    // Key code LUT (mapping X11 key codes to GLFW key codes)
+    // LUT for mapping X11 key codes to GLFW key codes
     int             keyCodeLUT[256];
 
-    // Screensaver data
     struct {
         GLboolean   changed;
         int         timeout;
@@ -173,14 +174,12 @@
         int         exposure;
     } saver;
 
-    // Timer data
     struct {
         GLboolean   monotonic;
         double      resolution;
         uint64_t    base;
     } timer;
 
-    // Selection data
     struct {
         Atom        atom;
         Atom        formats[_GLFW_CLIPBOARD_FORMAT_COUNT];
diff --git a/src/x11_window.c b/src/x11_window.c
index e328f3b..7fb7747 100644
--- a/src/x11_window.c
+++ b/src/x11_window.c
@@ -109,9 +109,9 @@
 
         if (wndconfig->monitor == NULL)
         {
-            // The /only/ reason for setting the background pixel here is that
-            // otherwise our window won't get any decorations on systems using
-            // certain versions of Compiz on Intel hardware
+            // HACK: This is a workaround for windows without a background pixel
+            // not getting any decorations on certain older versions of Compiz
+            // running on Intel hardware
             wa.background_pixel = BlackPixel(_glfw.x11.display,
                                              _glfw.x11.screen);
             wamask |= CWBackPixel;
@@ -400,13 +400,6 @@
         XResizeWindow(_glfw.x11.display, window->x11.handle,
                       window->width, window->height);
     }
-
-    // HACK: Try to get window inside viewport (for virtual displays) by moving
-    // the cursor to the upper left corner (and then to the center)
-    // This hack should be harmless on saner systems as well
-    XWarpPointer(_glfw.x11.display, None, window->x11.handle, 0,0,0,0, 0,0);
-    XWarpPointer(_glfw.x11.display, None, window->x11.handle, 0,0,0,0,
-                 window->width / 2, window->height / 2);
 }