Blame patches/sdl2/wchar.patch

d7cf18
diff -ru SDL2-2.0.12.orig/src/video/windows/SDL_windowsmessagebox.c SDL2-2.0.12/src/video/windows/SDL_windowsmessagebox.c
d7cf18
--- SDL2-2.0.12.orig/src/video/windows/SDL_windowsmessagebox.c  2020-03-11 02:36:18.000000000 +0100
d7cf18
+++ SDL2-2.0.12/src/video/windows/SDL_windowsmessagebox.c       2020-10-07 14:04:09.877146877 +0200
d7cf18
@@ -803,7 +803,7 @@
213fe0
     }
d7cf18
d7cf18
     /* If we cannot load comctl32.dll use the old messagebox! */
d7cf18
-    hComctl32 = LoadLibrary(TEXT("Comctl32.dll"));
d7cf18
+    hComctl32 = LoadLibrary((uint16_t[]){'C','o','m','c','t','l','3','2','.','d','l','l',0});
d7cf18
     if (hComctl32 == NULL) {
d7cf18
         return WIN_ShowOldMessageBox(messageboxdata, buttonid);
d7cf18
     }
d7cf18
diff -ru SDL2-2.0.12.orig/src/video/windows/SDL_windowsevents.c SDL2-2.0.12/src/video/windows/SDL_windowsevents.c
d7cf18
--- SDL2-2.0.12.orig/src/video/windows/SDL_windowsevents.c      2020-03-11 02:36:18.000000000 +0100
d7cf18
+++ SDL2-2.0.12/src/video/windows/SDL_windowsevents.c   2020-10-07 14:00:09.021392356 +0200
d7cf18
@@ -416,7 +416,7 @@
d7cf18
     }
d7cf18
213fe0
     /* Get the window data for the window */
d7cf18
-    data = (SDL_WindowData *) GetProp(hwnd, TEXT("SDL_WindowData"));
d7cf18
+    data = (SDL_WindowData *) GetProp(hwnd, (uint16_t[]){'S','D','L','_','W','i','n','d','o','w','D','a','t','a',0});
213fe0
     if (!data) {
213fe0
         return CallWindowProc(DefWindowProc, hwnd, msg, wParam, lParam);
213fe0
     }
213fe0
diff -ru SDL2-2.0.8.orig/src/video/windows/SDL_windowswindow.c SDL2-2.0.8/src/video/windows/SDL_windowswindow.c
213fe0
--- SDL2-2.0.8.orig/src/video/windows/SDL_windowswindow.c	2018-03-01 17:34:42.000000000 +0100
213fe0
+++ SDL2-2.0.8/src/video/windows/SDL_windowswindow.c	2020-10-05 13:23:58.342720394 +0200
213fe0
@@ -45,10 +45,22 @@
213fe0
 #define SWP_NOCOPYBITS 0
213fe0
 #endif
213fe0
 
213fe0
+#ifdef __midipix__
213fe0
+#define sdl_helper_window_input_catcher (uint16_t[]){'S','D','L','H','e','l','p','e','r','W','i','n','d','o','w','I','n','p','u','t','C','a','t','c','h','e','r',0}
213fe0
+#define sdl_helper_window_name (uint16_t[]){'S','D','L','H','e','l','p','e','r','W','i','n','d','o','w','I','n','p','u','t','M','s','g','W','i','n','d','o','w',0}
213fe0
+#define sdl_window (uint16_t[]){'S','D','L','_','W','i','n','d','o','w','D','a','t','a',0}
213fe0
+#define sdl_empty (uint16_t[]){0}
213fe0
+#endif
213fe0
+
213fe0
 /* Fake window to help with DirectInput events. */
213fe0
 HWND SDL_HelperWindow = NULL;
213fe0
+#ifdef __midipix__
213fe0
+static WCHAR *SDL_HelperWindowClassName = sdl_helper_window_input_catcher;
213fe0
+static WCHAR *SDL_HelperWindowName = sdl_helper_window_name;
213fe0
+#else
213fe0
 static WCHAR *SDL_HelperWindowClassName = TEXT("SDLHelperWindowInputCatcher");
213fe0
 static WCHAR *SDL_HelperWindowName = TEXT("SDLHelperWindowInputMsgWindow");
213fe0
+#endif
213fe0
 static ATOM SDL_HelperWindowClass = 0;
213fe0
 
213fe0
 /* For borderless Windows, still want the following flags:
213fe0
@@ -183,7 +195,11 @@
213fe0
     window->driverdata = data;
213fe0
 
213fe0
     /* Associate the data with the window */
213fe0
+#ifdef __midipix__
213fe0
+    if (!SetProp(hwnd, sdl_window, data)) {
213fe0
+#else
213fe0
     if (!SetProp(hwnd, TEXT("SDL_WindowData"), data)) {
213fe0
+#endif
213fe0
         ReleaseDC(hwnd, data->hdc);
213fe0
         SDL_free(data);
213fe0
         return WIN_SetError("SetProp() failed");
213fe0
@@ -307,7 +323,11 @@
213fe0
     int w, h;
213fe0
 
213fe0
     if (window->flags & SDL_WINDOW_SKIP_TASKBAR) {
213fe0
+#ifdef __midipix__
213fe0
+        parent = CreateWindow(SDL_Appname, sdl_empty, STYLE_BASIC, 0, 0, 32, 32, NULL, NULL, SDL_Instance, NULL);
213fe0
+#else
213fe0
         parent = CreateWindow(SDL_Appname, TEXT(""), STYLE_BASIC, 0, 0, 32, 32, NULL, NULL, SDL_Instance, NULL);
213fe0
+#endif
213fe0
     }
213fe0
 
213fe0
     style |= GetWindowStyle(window);
213fe0
@@ -315,9 +335,13 @@
213fe0
     /* Figure out what the window area will be */
213fe0
     WIN_AdjustWindowRectWithStyle(window, style, FALSE, &x, &y, &w, &h, SDL_FALSE);
213fe0
 
213fe0
+#ifdef __midipix__
213fe0
+    hwnd = CreateWindow(SDL_Appname, sdl_empty, style, x, y, w, h, parent, NULL, SDL_Instance, NULL);
213fe0
+#else
213fe0
     hwnd =
213fe0
         CreateWindow(SDL_Appname, TEXT(""), style, x, y, w, h, parent, NULL,
213fe0
                      SDL_Instance, NULL);
213fe0
+#endif
213fe0
     if (!hwnd) {
213fe0
         return WIN_SetError("Couldn't create window");
213fe0
     }
213fe0
@@ -741,7 +765,11 @@
213fe0
 
213fe0
     if (data) {
213fe0
         ReleaseDC(data->hwnd, data->hdc);
213fe0
+#ifdef __midipix__
213fe0
+        RemoveProp(data->hwnd, sdl_window);
213fe0
+#else
213fe0
         RemoveProp(data->hwnd, TEXT("SDL_WindowData"));
213fe0
+#endif
213fe0
         if (data->created) {
213fe0
             DestroyWindow(data->hwnd);
213fe0
             if (data->parent) {