Andrew Fenn : xinput: Added the function XInputGetState with test case.

Alexandre Julliard julliard at winehq.org
Tue Nov 11 08:35:44 CST 2008


Module: wine
Branch: master
Commit: 29789a8ef4729401f685f3f5d7960ba654711e08
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=29789a8ef4729401f685f3f5d7960ba654711e08

Author: Andrew Fenn <andrewfenn at gmail.com>
Date:   Mon Nov 10 16:32:33 2008 +0000

xinput: Added the function XInputGetState with test case.

---

 configure                        |    9 ++++
 configure.ac                     |    1 +
 dlls/xinput1_3/tests/Makefile.in |   13 ++++++
 dlls/xinput1_3/tests/xinput.c    |   81 ++++++++++++++++++++++++++++++++++++++
 dlls/xinput1_3/xinput1_3.spec    |    2 +-
 dlls/xinput1_3/xinput1_3_main.c  |   14 +++++++
 6 files changed, 119 insertions(+), 1 deletions(-)

diff --git a/configure b/configure
index 316e9cf..9c677ee 100755
--- a/configure
+++ b/configure
@@ -26858,6 +26858,14 @@ dlls/xinput1_3/Makefile: dlls/xinput1_3/Makefile.in dlls/Makedll.rules"
 ac_config_files="$ac_config_files dlls/xinput1_3/Makefile"
 
 ALL_MAKEFILES="$ALL_MAKEFILES \\
+	dlls/xinput1_3/tests/Makefile"
+test "x$enable_xinput1_3_tests" != xno && ALL_TEST_DIRS="$ALL_TEST_DIRS \\
+	xinput1_3/tests"
+ALL_MAKEFILE_DEPENDS="$ALL_MAKEFILE_DEPENDS
+dlls/xinput1_3/tests/Makefile: dlls/xinput1_3/tests/Makefile.in dlls/Maketest.rules"
+ac_config_files="$ac_config_files dlls/xinput1_3/tests/Makefile"
+
+ALL_MAKEFILES="$ALL_MAKEFILES \\
 	dlls/xinput9_1_0/Makefile"
 test "x$enable_xinput9_1_0" != xno && ALL_DLL_DIRS="$ALL_DLL_DIRS \\
 	xinput9_1_0"
@@ -28400,6 +28408,7 @@ do
     "dlls/xinput1_1/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/xinput1_1/Makefile" ;;
     "dlls/xinput1_2/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/xinput1_2/Makefile" ;;
     "dlls/xinput1_3/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/xinput1_3/Makefile" ;;
+    "dlls/xinput1_3/tests/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/xinput1_3/tests/Makefile" ;;
     "dlls/xinput9_1_0/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/xinput9_1_0/Makefile" ;;
     "documentation/Makefile") CONFIG_FILES="$CONFIG_FILES documentation/Makefile" ;;
     "fonts/Makefile") CONFIG_FILES="$CONFIG_FILES fonts/Makefile" ;;
diff --git a/configure.ac b/configure.ac
index ed61fbe..00f2ddb 100644
--- a/configure.ac
+++ b/configure.ac
@@ -2097,6 +2097,7 @@ WINE_CONFIG_MAKEFILE([dlls/wtsapi32/Makefile],[dlls/Makedll.rules],[dlls],[ALL_D
 WINE_CONFIG_MAKEFILE([dlls/xinput1_1/Makefile],[dlls/Makedll.rules],[dlls],[ALL_DLL_DIRS])
 WINE_CONFIG_MAKEFILE([dlls/xinput1_2/Makefile],[dlls/Makedll.rules],[dlls],[ALL_DLL_DIRS])
 WINE_CONFIG_MAKEFILE([dlls/xinput1_3/Makefile],[dlls/Makedll.rules],[dlls],[ALL_DLL_DIRS])
+WINE_CONFIG_MAKEFILE([dlls/xinput1_3/tests/Makefile],[dlls/Maketest.rules],[dlls],[ALL_TEST_DIRS])
 WINE_CONFIG_MAKEFILE([dlls/xinput9_1_0/Makefile],[dlls/Makedll.rules],[dlls],[ALL_DLL_DIRS])
 WINE_CONFIG_MAKEFILE([documentation/Makefile],[Make.rules],[],[ALL_TOP_DIRS])
 WINE_CONFIG_MAKEFILE([fonts/Makefile],[Make.rules],[],[ALL_TOP_DIRS])
diff --git a/dlls/xinput1_3/tests/Makefile.in b/dlls/xinput1_3/tests/Makefile.in
new file mode 100644
index 0000000..e38b858
--- /dev/null
+++ b/dlls/xinput1_3/tests/Makefile.in
@@ -0,0 +1,13 @@
+TOPSRCDIR = @top_srcdir@
+TOPOBJDIR = ../../..
+SRCDIR    = @srcdir@
+VPATH     = @srcdir@
+TESTDLL   = xinput1_3.dll
+IMPORTS   = user32 kernel32
+
+CTESTS = \
+	xinput.c
+
+ at MAKE_TEST_RULES@
+
+ at DEPENDENCIES@  # everything below this line is overwritten by make depend
diff --git a/dlls/xinput1_3/tests/xinput.c b/dlls/xinput1_3/tests/xinput.c
new file mode 100644
index 0000000..2cdc168
--- /dev/null
+++ b/dlls/xinput1_3/tests/xinput.c
@@ -0,0 +1,81 @@
+/*
+ * The Wine project - Xinput Joystick Library
+ * Copyright 2008 Andrew Fenn
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+#include <windows.h>
+#include <stdio.h>
+
+#include "xinput.h"
+#include "wine/test.h"
+
+static DWORD (WINAPI *pXInputGetState)(DWORD, XINPUT_STATE*);
+
+static void test_get_state(void)
+{
+
+    XINPUT_STATE controllerState;
+    DWORD controllerNum;
+    DWORD result;
+
+    for(controllerNum=0; controllerNum < XUSER_MAX_COUNT; controllerNum++)
+    {
+        ZeroMemory(&controllerState, sizeof(XINPUT_STATE));
+
+        result = pXInputGetState(controllerNum, &controllerState);
+        ok(result == ERROR_SUCCESS || result == ERROR_DEVICE_NOT_CONNECTED, "XInputGetState failed with (%d)\n", result);
+
+        if (ERROR_DEVICE_NOT_CONNECTED == result)
+        {
+            skip("Controller %d is not connected\n", controllerNum);
+        }
+        else
+        {
+            trace("-- Results for controller %d --\n", controllerNum);
+            trace("XInputGetState: %d\n", result);
+            trace("State->dwPacketNumber: %d\n", controllerState.dwPacketNumber);
+            trace("Gamepad Variables --\n");
+            trace("Gamepad.wButtons: %#x\n", controllerState.Gamepad.wButtons);
+            trace("Gamepad.bLeftTrigger: 0x%08x\n", controllerState.Gamepad.bLeftTrigger);
+            trace("Gamepad.bRightTrigger: 0x%08x\n", controllerState.Gamepad.bRightTrigger);
+            trace("Gamepad.sThumbLX: %d\n", controllerState.Gamepad.sThumbLX);
+            trace("Gamepad.sThumbLY: %d\n", controllerState.Gamepad.sThumbLY);
+            trace("Gamepad.sThumbRX: %d\n", controllerState.Gamepad.sThumbRX);
+            trace("Gamepad.sThumbRY: %d\n", controllerState.Gamepad.sThumbRY);
+        }
+    }
+
+    ZeroMemory(&controllerState, sizeof(XINPUT_STATE));
+    result = pXInputGetState(XUSER_MAX_COUNT+1, &controllerState);
+    ok(result == ERROR_BAD_ARGUMENTS, "XInputGetState returned (%d)\n", result);
+}
+
+START_TEST(xinput)
+{
+    HMODULE hXinput;
+    hXinput = LoadLibraryA( "xinput1_3.dll" );
+
+    if (hXinput)
+    {
+        pXInputGetState = (void*)GetProcAddress(hXinput, "XInputGetState");
+        test_get_state();
+    }
+    else
+    {
+        skip("Could not load xinput1_3.dll\n");
+    }
+}
diff --git a/dlls/xinput1_3/xinput1_3.spec b/dlls/xinput1_3/xinput1_3.spec
index 5caaa37..8fb6353 100644
--- a/dlls/xinput1_3/xinput1_3.spec
+++ b/dlls/xinput1_3/xinput1_3.spec
@@ -1,6 +1,6 @@
 @ stub XInputEnable #(long)
 @ stub XInputSetState #(long ptr)
-@ stub XInputGetState #(long ptr)
+@ stdcall XInputGetState(long ptr)
 @ stub XInputGetKeystroke #(long long ptr)
 @ stub XInputGetCapabilities #(long long ptr)
 @ stub XInputGetDSoundAudioDeviceGuids #(long ptr ptr)
diff --git a/dlls/xinput1_3/xinput1_3_main.c b/dlls/xinput1_3/xinput1_3_main.c
index 6198b3b..f2b6500 100644
--- a/dlls/xinput1_3/xinput1_3_main.c
+++ b/dlls/xinput1_3/xinput1_3_main.c
@@ -27,6 +27,8 @@
 #include "winbase.h"
 #include "winerror.h"
 
+#include "xinput.h"
+
 WINE_DEFAULT_DEBUG_CHANNEL(xinput);
 
 BOOL WINAPI DllMain(HINSTANCE inst, DWORD reason, LPVOID reserved)
@@ -43,3 +45,15 @@ BOOL WINAPI DllMain(HINSTANCE inst, DWORD reason, LPVOID reserved)
     }
     return TRUE;
 }
+
+DWORD WINAPI XInputGetState(DWORD dwUserIndex, XINPUT_STATE* pState)
+{
+    FIXME("(%u %p)\n", dwUserIndex, pState);
+
+    if (dwUserIndex < XUSER_MAX_COUNT)
+    {
+        return ERROR_DEVICE_NOT_CONNECTED;
+        /* If controller exists then return ERROR_SUCCESS */
+    }
+    return ERROR_BAD_ARGUMENTS;
+}




More information about the wine-cvs mailing list