Merge pull request #12631 from jordan-woyak/remove-osx-input-leftovers
InputCommon: Remove some IOKit leftovers.
This commit is contained in:
commit
4421cc471d
|
@ -114,8 +114,6 @@ elseif(APPLE)
|
||||||
ControllerInterface/Quartz/Quartz.mm
|
ControllerInterface/Quartz/Quartz.mm
|
||||||
ControllerInterface/Quartz/QuartzKeyboardAndMouse.h
|
ControllerInterface/Quartz/QuartzKeyboardAndMouse.h
|
||||||
ControllerInterface/Quartz/QuartzKeyboardAndMouse.mm
|
ControllerInterface/Quartz/QuartzKeyboardAndMouse.mm
|
||||||
ControllerInterface/ForceFeedback/ForceFeedbackDevice.cpp
|
|
||||||
ControllerInterface/ForceFeedback/ForceFeedbackDevice.h
|
|
||||||
)
|
)
|
||||||
target_link_libraries(inputcommon PRIVATE
|
target_link_libraries(inputcommon PRIVATE
|
||||||
${COREFOUNDATION_LIBRARY}
|
${COREFOUNDATION_LIBRARY}
|
||||||
|
|
|
@ -7,16 +7,13 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <thread>
|
#include <thread>
|
||||||
|
|
||||||
|
#include <Windows.h>
|
||||||
|
|
||||||
#include "Common/Event.h"
|
#include "Common/Event.h"
|
||||||
#include "Common/Flag.h"
|
#include "Common/Flag.h"
|
||||||
#include "InputCommon/ControllerInterface/CoreDevice.h"
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
#include "InputCommon/ControllerInterface/CoreDevice.h"
|
||||||
#include <Windows.h>
|
|
||||||
#include "InputCommon/ControllerInterface/DInput/DInput8.h"
|
#include "InputCommon/ControllerInterface/DInput/DInput8.h"
|
||||||
#elif __APPLE__
|
|
||||||
#include "InputCommon/ControllerInterface/ForceFeedback/OSX/DirectInputAdapter.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace ciface::ForceFeedback
|
namespace ciface::ForceFeedback
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,196 +0,0 @@
|
||||||
// Copyright 2014 Dolphin Emulator Project
|
|
||||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The OS X Force Feedback API is very similar to the DirectInput API,
|
|
||||||
* but it is no longer object-oriented and all prefixes have been changed.
|
|
||||||
*
|
|
||||||
* Our implementation uses the Windows API names so we need to adapt
|
|
||||||
* for these differences on OS X.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#include <atomic>
|
|
||||||
|
|
||||||
typedef LONG* LPLONG; // Missing type for ForceFeedback.h
|
|
||||||
#include <CoreFoundation/CoreFoundation.h>
|
|
||||||
#include <ForceFeedback/ForceFeedback.h>
|
|
||||||
#include "Common/CommonTypes.h" // for LONG
|
|
||||||
#include "DirectInputConstants.h" // Not stricty necessary
|
|
||||||
|
|
||||||
namespace ciface::ForceFeedback
|
|
||||||
{
|
|
||||||
// Prototypes
|
|
||||||
class IUnknownImpl;
|
|
||||||
class FFEffectAdapter;
|
|
||||||
class FFDeviceAdapter;
|
|
||||||
|
|
||||||
// Structs
|
|
||||||
typedef FFCAPABILITIES DICAPABILITIES;
|
|
||||||
typedef FFCONDITION DICONDITION;
|
|
||||||
typedef FFCONSTANTFORCE DICONSTANTFORCE;
|
|
||||||
typedef FFCUSTOMFORCE DICUSTOMFORCE;
|
|
||||||
typedef FFEFFECT DIEFFECT;
|
|
||||||
typedef FFEFFESCAPE DIEFFESCAPE;
|
|
||||||
typedef FFENVELOPE DIENVELOPE;
|
|
||||||
typedef FFPERIODIC DIPERIODIC;
|
|
||||||
typedef FFRAMPFORCE DIRAMPFORCE;
|
|
||||||
|
|
||||||
// Other types
|
|
||||||
typedef CFUUIDRef GUID;
|
|
||||||
typedef FFDeviceAdapter* FFDeviceAdapterReference;
|
|
||||||
typedef FFEffectAdapter* FFEffectAdapterReference;
|
|
||||||
typedef FFDeviceAdapterReference LPDIRECTINPUTDEVICE8;
|
|
||||||
typedef FFEffectAdapterReference LPDIRECTINPUTEFFECT;
|
|
||||||
|
|
||||||
// Property structures
|
|
||||||
#define DIPH_DEVICE 0
|
|
||||||
|
|
||||||
typedef struct DIPROPHEADER
|
|
||||||
{
|
|
||||||
DWORD dwSize;
|
|
||||||
DWORD dwHeaderSize;
|
|
||||||
DWORD dwObj;
|
|
||||||
DWORD dwHow;
|
|
||||||
} DIPROPHEADER, *LPDIPROPHEADER;
|
|
||||||
|
|
||||||
typedef struct DIPROPDWORD
|
|
||||||
{
|
|
||||||
DIPROPHEADER diph;
|
|
||||||
DWORD dwData;
|
|
||||||
} DIPROPDWORD, *LPDIPROPDWORD;
|
|
||||||
|
|
||||||
class IUnknownImpl : public IUnknown
|
|
||||||
{
|
|
||||||
private:
|
|
||||||
std::atomic<ULONG> m_cRef;
|
|
||||||
|
|
||||||
public:
|
|
||||||
IUnknownImpl() : m_cRef(1) {}
|
|
||||||
virtual ~IUnknownImpl() {}
|
|
||||||
HRESULT QueryInterface(REFIID iid, LPVOID* ppv)
|
|
||||||
{
|
|
||||||
*ppv = nullptr;
|
|
||||||
|
|
||||||
if (CFEqual(&iid, IUnknownUUID))
|
|
||||||
*ppv = this;
|
|
||||||
if (nullptr == *ppv)
|
|
||||||
return E_NOINTERFACE;
|
|
||||||
|
|
||||||
((IUnknown*)*ppv)->AddRef();
|
|
||||||
|
|
||||||
return S_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
ULONG AddRef() { return ++m_cRef; }
|
|
||||||
ULONG Release()
|
|
||||||
{
|
|
||||||
if (--m_cRef == 0)
|
|
||||||
delete this;
|
|
||||||
|
|
||||||
return m_cRef;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
class FFEffectAdapter : public IUnknownImpl
|
|
||||||
{
|
|
||||||
private:
|
|
||||||
// Only used for destruction
|
|
||||||
FFDeviceObjectReference m_device;
|
|
||||||
|
|
||||||
public:
|
|
||||||
FFEffectObjectReference m_effect;
|
|
||||||
|
|
||||||
FFEffectAdapter(FFDeviceObjectReference device, FFEffectObjectReference effect)
|
|
||||||
: m_device(device), m_effect(effect)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
~FFEffectAdapter() { FFDeviceReleaseEffect(m_device, m_effect); }
|
|
||||||
HRESULT Download() { return FFEffectDownload(m_effect); }
|
|
||||||
HRESULT Escape(FFEFFESCAPE* pFFEffectEscape) { return FFEffectEscape(m_effect, pFFEffectEscape); }
|
|
||||||
HRESULT GetEffectStatus(FFEffectStatusFlag* pFlags)
|
|
||||||
{
|
|
||||||
return FFEffectGetEffectStatus(m_effect, pFlags);
|
|
||||||
}
|
|
||||||
|
|
||||||
HRESULT GetParameters(FFEFFECT* pFFEffect, FFEffectParameterFlag flags)
|
|
||||||
{
|
|
||||||
return FFEffectGetParameters(m_effect, pFFEffect, flags);
|
|
||||||
}
|
|
||||||
|
|
||||||
HRESULT SetParameters(FFEFFECT* pFFEffect, FFEffectParameterFlag flags)
|
|
||||||
{
|
|
||||||
return FFEffectSetParameters(m_effect, pFFEffect, flags);
|
|
||||||
}
|
|
||||||
|
|
||||||
HRESULT Start(UInt32 iterations, FFEffectStartFlag flags)
|
|
||||||
{
|
|
||||||
return FFEffectStart(m_effect, iterations, flags);
|
|
||||||
}
|
|
||||||
|
|
||||||
HRESULT Stop() { return FFEffectStop(m_effect); }
|
|
||||||
HRESULT Unload() { return FFEffectUnload(m_effect); }
|
|
||||||
};
|
|
||||||
|
|
||||||
class FFDeviceAdapter : public IUnknownImpl
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
FFDeviceObjectReference m_device;
|
|
||||||
|
|
||||||
FFDeviceAdapter(FFDeviceObjectReference device) : m_device(device) {}
|
|
||||||
~FFDeviceAdapter() { FFReleaseDevice(m_device); }
|
|
||||||
static HRESULT Create(io_service_t hidDevice, FFDeviceAdapterReference* pDeviceReference)
|
|
||||||
{
|
|
||||||
FFDeviceObjectReference ref;
|
|
||||||
|
|
||||||
HRESULT hr = FFCreateDevice(hidDevice, &ref);
|
|
||||||
if (SUCCEEDED(hr))
|
|
||||||
*pDeviceReference = new FFDeviceAdapter(ref);
|
|
||||||
|
|
||||||
return hr;
|
|
||||||
}
|
|
||||||
|
|
||||||
HRESULT CreateEffect(CFUUIDRef uuidRef, FFEFFECT* pEffectDefinition,
|
|
||||||
FFEffectAdapterReference* pEffectReference, IUnknown* punkOuter)
|
|
||||||
{
|
|
||||||
FFEffectObjectReference ref;
|
|
||||||
|
|
||||||
HRESULT hr = FFDeviceCreateEffect(m_device, uuidRef, pEffectDefinition, &ref);
|
|
||||||
if (SUCCEEDED(hr))
|
|
||||||
*pEffectReference = new FFEffectAdapter(m_device, ref);
|
|
||||||
|
|
||||||
return hr;
|
|
||||||
}
|
|
||||||
|
|
||||||
HRESULT Escape(FFEFFESCAPE* pFFEffectEscape) { return FFDeviceEscape(m_device, pFFEffectEscape); }
|
|
||||||
HRESULT GetForceFeedbackState(FFState* pFFState)
|
|
||||||
{
|
|
||||||
return FFDeviceGetForceFeedbackState(m_device, pFFState);
|
|
||||||
}
|
|
||||||
|
|
||||||
HRESULT SendForceFeedbackCommand(FFCommandFlag flags)
|
|
||||||
{
|
|
||||||
return FFDeviceSendForceFeedbackCommand(m_device, flags);
|
|
||||||
}
|
|
||||||
|
|
||||||
HRESULT SetCooperativeLevel(void* taskIdentifier, FFCooperativeLevelFlag flags)
|
|
||||||
{
|
|
||||||
return FFDeviceSetCooperativeLevel(m_device, taskIdentifier, flags);
|
|
||||||
}
|
|
||||||
|
|
||||||
HRESULT SetProperty(FFProperty property, const LPDIPROPHEADER pdiph)
|
|
||||||
{
|
|
||||||
// There are only two properties supported
|
|
||||||
if (property != DIPROP_FFGAIN && property != DIPROP_AUTOCENTER)
|
|
||||||
return DIERR_UNSUPPORTED;
|
|
||||||
|
|
||||||
// And they are both device properties
|
|
||||||
if (pdiph->dwHow != DIPH_DEVICE)
|
|
||||||
return DIERR_INVALIDPARAM;
|
|
||||||
|
|
||||||
UInt32 value = ((const LPDIPROPDWORD)pdiph)->dwData;
|
|
||||||
return FFDeviceSetForceFeedbackProperty(m_device, property, &value);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
} // namespace ciface::ForceFeedback
|
|
|
@ -1,146 +0,0 @@
|
||||||
// Copyright 2014 Dolphin Emulator Project
|
|
||||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Define all constants from ForceFeedbackConstants.h with DirectInput prefixes.
|
|
||||||
*
|
|
||||||
* No effort was made to confirm if all definitions are actually supported by
|
|
||||||
* DirectInput, so some of these definitions may actually only exist on Mac OS X.
|
|
||||||
*/
|
|
||||||
|
|
||||||
// UUIDs
|
|
||||||
#define GUID_ConstantForce kFFEffectType_ConstantForce_ID
|
|
||||||
#define GUID_CustomForce kFFEffectType_CustomForce_ID
|
|
||||||
#define GUID_Damper kFFEffectType_Damper_ID
|
|
||||||
#define GUID_Friction kFFEffectType_Friction_ID
|
|
||||||
#define GUID_Inertia kFFEffectType_Inertia_ID
|
|
||||||
#define GUID_RampForce kFFEffectType_RampForce_ID
|
|
||||||
#define GUID_SawtoothDown kFFEffectType_SawtoothDown_ID
|
|
||||||
#define GUID_SawtoothUp kFFEffectType_SawtoothUp_ID
|
|
||||||
#define GUID_Sine kFFEffectType_Sine_ID
|
|
||||||
#define GUID_Spring kFFEffectType_Spring_ID
|
|
||||||
#define GUID_Square kFFEffectType_Square_ID
|
|
||||||
#define GUID_Triangle kFFEffectType_Triangle_ID
|
|
||||||
|
|
||||||
// Miscellaneous
|
|
||||||
#define DI_DEGREES FF_DEGREES
|
|
||||||
#define DI_DOWNLOADSKIPPED FF_DOWNLOADSKIPPED
|
|
||||||
#define DI_EFFECTRESTARTED FF_EFFECTRESTARTED
|
|
||||||
#define DI_FALSE FF_FALSE
|
|
||||||
#define DI_FFNOMINALMAX FF_FFNOMINALMAX
|
|
||||||
#define DI_INFINITE FF_INFINITE
|
|
||||||
#define DI_OK FF_OK
|
|
||||||
#define DI_SECONDS FF_SECONDS
|
|
||||||
#define DI_TRUNCATED FF_TRUNCATED
|
|
||||||
#define DI_TRUNCATEDANDRESTARTED FF_TRUNCATEDANDRESTARTED
|
|
||||||
#define DIEFF_OBJECTOFFSETS FFEFF_OBJECTOFFSETS
|
|
||||||
#define DIERR_DEVICEFULL FFERR_DEVICEFULL
|
|
||||||
#define DIERR_DEVICENOTREG FFERR_DEVICENOTREG
|
|
||||||
#define DIERR_DEVICEPAUSED FFERR_DEVICEPAUSED
|
|
||||||
#define DIERR_DEVICERELEASED FFERR_DEVICERELEASED
|
|
||||||
#define DIERR_EFFECTPLAYING FFERR_EFFECTPLAYING
|
|
||||||
#define DIERR_EFFECTTYPEMISMATCH FFERR_EFFECTTYPEMISMATCH
|
|
||||||
#define DIERR_EFFECTTYPENOTSUPPORTED FFERR_EFFECTTYPENOTSUPPORTED
|
|
||||||
#define DIERR_GENERIC FFERR_GENERIC
|
|
||||||
#define DIERR_HASEFFECTS FFERR_HASEFFECTS
|
|
||||||
#define DIERR_INCOMPLETEEFFECT FFERR_INCOMPLETEEFFECT
|
|
||||||
#define DIERR_INTERNAL FFERR_INTERNAL
|
|
||||||
#define DIERR_INVALIDDOWNLOADID FFERR_INVALIDDOWNLOADID
|
|
||||||
#define DIERR_INVALIDPARAM FFERR_INVALIDPARAM
|
|
||||||
#define DIERR_MOREDATA FFERR_MOREDATA
|
|
||||||
#define DIERR_NOINTERFACE FFERR_NOINTERFACE
|
|
||||||
#define DIERR_NOTDOWNLOADED FFERR_NOTDOWNLOADED
|
|
||||||
#define DIERR_NOTINITIALIZED FFERR_NOTINITIALIZED
|
|
||||||
#define DIERR_OUTOFMEMORY FFERR_OUTOFMEMORY
|
|
||||||
#define DIERR_UNPLUGGED FFERR_UNPLUGGED
|
|
||||||
#define DIERR_UNSUPPORTED FFERR_UNSUPPORTED
|
|
||||||
#define DIERR_UNSUPPORTEDAXIS FFERR_UNSUPPORTEDAXIS
|
|
||||||
#define DIJOFS_X FFJOFS_X
|
|
||||||
#define DIJOFS_Y FFJOFS_Y
|
|
||||||
#define DIJOFS_Z FFJOFS_Z
|
|
||||||
|
|
||||||
// FFCapabilitiesEffectSubType
|
|
||||||
#define DICAP_ST_KINESTHETIC FFCAP_ST_KINESTHETIC
|
|
||||||
#define DICAP_ST_VIBRATION FFCAP_ST_VIBRATION
|
|
||||||
|
|
||||||
// FFCapabilitiesEffectType
|
|
||||||
#define DICAP_ET_CONSTANTFORCE FFCAP_ET_CONSTANTFORCE
|
|
||||||
#define DICAP_ET_RAMPFORCE FFCAP_ET_RAMPFORCE
|
|
||||||
#define DICAP_ET_SQUARE FFCAP_ET_SQUARE
|
|
||||||
#define DICAP_ET_SINE FFCAP_ET_SINE
|
|
||||||
#define DICAP_ET_TRIANGLE FFCAP_ET_TRIANGLE
|
|
||||||
#define DICAP_ET_SAWTOOTHUP FFCAP_ET_SAWTOOTHUP
|
|
||||||
#define DICAP_ET_SAWTOOTHDOWN FFCAP_ET_SAWTOOTHDOWN
|
|
||||||
#define DICAP_ET_SPRING FFCAP_ET_SPRING
|
|
||||||
#define DICAP_ET_DAMPER FFCAP_ET_DAMPER
|
|
||||||
#define DICAP_ET_INERTIA FFCAP_ET_INERTIA
|
|
||||||
#define DICAP_ET_FRICTION FFCAP_ET_FRICTION
|
|
||||||
#define DICAP_ET_CUSTOMFORCE FFCAP_ET_CUSTOMFORCE
|
|
||||||
|
|
||||||
// FFCommandFlag
|
|
||||||
#define DISFFC_RESET FFSFFC_RESET
|
|
||||||
#define DISFFC_STOPALL FFSFFC_STOPALL
|
|
||||||
#define DISFFC_PAUSE FFSFFC_PAUSE
|
|
||||||
#define DISFFC_CONTINUE FFSFFC_CONTINUE
|
|
||||||
#define DISFFC_SETACTUATORSON FFSFFC_SETACTUATORSON
|
|
||||||
#define DISFFC_SETACTUATORSOFF FFSFFC_SETACTUATORSOFF
|
|
||||||
|
|
||||||
// FFCooperativeLevelFlag
|
|
||||||
#define DISCL_EXCLUSIVE FFSCL_EXCLUSIVE
|
|
||||||
#define DISCL_NONEXCLUSIVE FFSCL_NONEXCLUSIVE
|
|
||||||
#define DISCL_FOREGROUND FFSCL_FOREGROUND
|
|
||||||
#define DISCL_BACKGROUND FFSCL_BACKGROUND
|
|
||||||
|
|
||||||
// FFCoordinateSystemFlag
|
|
||||||
#define DIEFF_CARTESIAN FFEFF_CARTESIAN
|
|
||||||
#define DIEFF_POLAR FFEFF_POLAR
|
|
||||||
#define DIEFF_SPHERICAL FFEFF_SPHERICAL
|
|
||||||
|
|
||||||
// FFEffectParameterFlag
|
|
||||||
#define DIEP_DURATION FFEP_DURATION
|
|
||||||
#define DIEP_SAMPLEPERIOD FFEP_SAMPLEPERIOD
|
|
||||||
#define DIEP_GAIN FFEP_GAIN
|
|
||||||
#define DIEP_TRIGGERBUTTON FFEP_TRIGGERBUTTON
|
|
||||||
#define DIEP_TRIGGERREPEATINTERVAL FFEP_TRIGGERREPEATINTERVAL
|
|
||||||
#define DIEP_AXES FFEP_AXES
|
|
||||||
#define DIEP_DIRECTION FFEP_DIRECTION
|
|
||||||
#define DIEP_ENVELOPE FFEP_ENVELOPE
|
|
||||||
#define DIEP_TYPESPECIFICPARAMS FFEP_TYPESPECIFICPARAMS
|
|
||||||
#define DIEP_STARTDELAY FFEP_STARTDELAY
|
|
||||||
#define DIEP_ALLPARAMS FFEP_ALLPARAMS
|
|
||||||
#define DIEP_START FFEP_START
|
|
||||||
#define DIEP_NORESTART FFEP_NORESTART
|
|
||||||
#define DIEP_NODOWNLOAD FFEP_NODOWNLOAD
|
|
||||||
#define DIEB_NOTRIGGER FFEB_NOTRIGGER
|
|
||||||
|
|
||||||
// FFEffectStartFlag
|
|
||||||
#define DIES_SOLO FFES_SOLO
|
|
||||||
#define DIES_NODOWNLOAD FFES_NODOWNLOAD
|
|
||||||
|
|
||||||
// FFEffectStatusFlag
|
|
||||||
#define DIEGES_NOTPLAYING FFEGES_NOTPLAYING
|
|
||||||
#define DIEGES_PLAYING FFEGES_PLAYING
|
|
||||||
#define DIEGES_EMULATED FFEGES_EMULATED
|
|
||||||
|
|
||||||
// FFProperty
|
|
||||||
#define DIPROP_FFGAIN FFPROP_FFGAIN
|
|
||||||
#define DIPROP_AUTOCENTER FFPROP_AUTOCENTER
|
|
||||||
// not defined in ForceFeedbackConstants.h
|
|
||||||
#define DIPROPAUTOCENTER_OFF 0
|
|
||||||
#define DIPROPAUTOCENTER_ON 1
|
|
||||||
|
|
||||||
// FFState
|
|
||||||
#define DIGFFS_EMPTY FFGFFS_EMPTY
|
|
||||||
#define DIGFFS_STOPPED FFGFFS_STOPPED
|
|
||||||
#define DIGFFS_PAUSED FFGFFS_PAUSED
|
|
||||||
#define DIGFFS_ACTUATORSON FFGFFS_ACTUATORSON
|
|
||||||
#define DIGFFS_ACTUATORSOFF FFGFFS_ACTUATORSOFF
|
|
||||||
#define DIGFFS_POWERON FFGFFS_POWERON
|
|
||||||
#define DIGFFS_POWEROFF FFGFFS_POWEROFF
|
|
||||||
#define DIGFFS_SAFETYSWITCHON FFGFFS_SAFETYSWITCHON
|
|
||||||
#define DIGFFS_SAFETYSWITCHOFF FFGFFS_SAFETYSWITCHOFF
|
|
||||||
#define DIGFFS_USERFFSWITCHON FFGFFS_USERFFSWITCHON
|
|
||||||
#define DIGFFS_USERFFSWITCHOFF FFGFFS_USERFFSWITCHOFF
|
|
||||||
#define DIGFFS_DEVICELOST FFGFFS_DEVICELOST
|
|
Loading…
Reference in New Issue