Update moonlight-common-c to pick up new input structures

This commit is contained in:
Cameron Gutman
2022-11-22 18:38:27 -06:00
parent fbd6807eb8
commit d912cce5ba
3 changed files with 38 additions and 60 deletions

View File

@@ -34,13 +34,6 @@ endif()
set(CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake) set(CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake)
set(SUNSHINE_SOURCE_ASSETS_DIR "${CMAKE_CURRENT_SOURCE_DIR}/src_assets") set(SUNSHINE_SOURCE_ASSETS_DIR "${CMAKE_CURRENT_SOURCE_DIR}/src_assets")
if(WIN32)
# Ugly hack to compile with #include <qos2.h>
add_compile_definitions(
QOS_FLOWID=UINT32
PQOS_FLOWID=UINT32*
QOS_NON_ADAPTIVE_FLOW=2)
endif()
if(APPLE) if(APPLE)
macro(ADD_FRAMEWORK fwname appname) macro(ADD_FRAMEWORK fwname appname)
find_library(FRAMEWORK_${fwname} find_library(FRAMEWORK_${fwname}

View File

@@ -4,6 +4,7 @@
#include <cstdint> #include <cstdint>
extern "C" { extern "C" {
#include <moonlight-common-c/src/Input.h> #include <moonlight-common-c/src/Input.h>
#include <moonlight-common-c/src/Limelight.h>
} }
#include <bitset> #include <bitset>
@@ -175,7 +176,7 @@ void print(PNV_ABS_MOUSE_MOVE_PACKET packet) {
void print(PNV_MOUSE_BUTTON_PACKET packet) { void print(PNV_MOUSE_BUTTON_PACKET packet) {
BOOST_LOG(debug) BOOST_LOG(debug)
<< "--begin mouse button packet--"sv << std::endl << "--begin mouse button packet--"sv << std::endl
<< "action ["sv << util::hex(packet->action).to_string_view() << ']' << std::endl << "action ["sv << util::hex(packet->header.magic).to_string_view() << ']' << std::endl
<< "button ["sv << util::hex(packet->button).to_string_view() << ']' << std::endl << "button ["sv << util::hex(packet->button).to_string_view() << ']' << std::endl
<< "--end mouse button packet--"sv; << "--end mouse button packet--"sv;
} }
@@ -190,7 +191,7 @@ void print(PNV_SCROLL_PACKET packet) {
void print(PNV_KEYBOARD_PACKET packet) { void print(PNV_KEYBOARD_PACKET packet) {
BOOST_LOG(debug) BOOST_LOG(debug)
<< "--begin keyboard packet--"sv << std::endl << "--begin keyboard packet--"sv << std::endl
<< "keyAction ["sv << util::hex(packet->keyAction).to_string_view() << ']' << std::endl << "keyAction ["sv << util::hex(packet->header.magic).to_string_view() << ']' << std::endl
<< "keyCode ["sv << util::hex(packet->keyCode).to_string_view() << ']' << std::endl << "keyCode ["sv << util::hex(packet->keyCode).to_string_view() << ']' << std::endl
<< "modifiers ["sv << util::hex(packet->modifiers).to_string_view() << ']' << std::endl << "modifiers ["sv << util::hex(packet->modifiers).to_string_view() << ']' << std::endl
<< "--end keyboard packet--"sv; << "--end keyboard packet--"sv;
@@ -212,33 +213,29 @@ void print(PNV_MULTI_CONTROLLER_PACKET packet) {
<< "--end controller packet--"sv; << "--end controller packet--"sv;
} }
constexpr int PACKET_TYPE_SCROLL_OR_KEYBOARD = PACKET_TYPE_SCROLL; void print(void *payload) {
void print(void *input) { auto header = (PNV_INPUT_HEADER)payload;
int input_type = util::endian::big(*(int *)input);
switch(input_type) { switch(util::endian::little(header->magic)) {
case PACKET_TYPE_REL_MOUSE_MOVE: case MOUSE_MOVE_REL_MAGIC_GEN5:
print((PNV_REL_MOUSE_MOVE_PACKET)input); print((PNV_REL_MOUSE_MOVE_PACKET)payload);
break; break;
case PACKET_TYPE_ABS_MOUSE_MOVE: case MOUSE_MOVE_ABS_MAGIC:
print((PNV_ABS_MOUSE_MOVE_PACKET)input); print((PNV_ABS_MOUSE_MOVE_PACKET)payload);
break; break;
case PACKET_TYPE_MOUSE_BUTTON: case MOUSE_BUTTON_DOWN_EVENT_MAGIC_GEN5:
print((PNV_MOUSE_BUTTON_PACKET)input); case MOUSE_BUTTON_UP_EVENT_MAGIC_GEN5:
print((PNV_MOUSE_BUTTON_PACKET)payload);
break; break;
case PACKET_TYPE_SCROLL_OR_KEYBOARD: { case SCROLL_MAGIC_GEN5:
char *tmp_input = (char *)input + 4; print((PNV_SCROLL_PACKET)payload);
if(tmp_input[0] == 0x0A) {
print((PNV_SCROLL_PACKET)input);
}
else {
print((PNV_KEYBOARD_PACKET)input);
}
break; break;
} case KEY_DOWN_EVENT_MAGIC:
case PACKET_TYPE_MULTI_CONTROLLER: case KEY_UP_EVENT_MAGIC:
print((PNV_MULTI_CONTROLLER_PACKET)input); print((PNV_KEYBOARD_PACKET)payload);
break;
case MULTI_CONTROLLER_MAGIC_GEN5:
print((PNV_MULTI_CONTROLLER_PACKET)payload);
break; break;
} }
} }
@@ -294,14 +291,8 @@ void passthrough(std::shared_ptr<input_t> &input, PNV_ABS_MOUSE_MOVE_PACKET pack
} }
void passthrough(std::shared_ptr<input_t> &input, PNV_MOUSE_BUTTON_PACKET packet) { void passthrough(std::shared_ptr<input_t> &input, PNV_MOUSE_BUTTON_PACKET packet) {
auto constexpr BUTTON_RELEASED = 0x09; auto release = util::endian::little(packet->header.magic) == MOUSE_BUTTON_UP_EVENT_MAGIC_GEN5;
auto button = util::endian::big(packet->button);
auto constexpr BUTTON_LEFT = 0x01;
auto constexpr BUTTON_RIGHT = 0x03;
auto release = packet->action == BUTTON_RELEASED;
auto button = util::endian::big(packet->button);
if(button > 0 && button < mouse_press.size()) { if(button > 0 && button < mouse_press.size()) {
if(mouse_press[button] != release) { if(mouse_press[button] != release) {
// button state is already what we want // button state is already what we want
@@ -417,9 +408,7 @@ void repeat_key(short key_code) {
} }
void passthrough(std::shared_ptr<input_t> &input, PNV_KEYBOARD_PACKET packet) { void passthrough(std::shared_ptr<input_t> &input, PNV_KEYBOARD_PACKET packet) {
auto constexpr BUTTON_RELEASED = 0x04; auto release = util::endian::little(packet->header.magic) == KEY_UP_EVENT_MAGIC;
auto release = packet->keyAction == BUTTON_RELEASED;
auto keyCode = packet->keyCode & 0x00FF; auto keyCode = packet->keyCode & 0x00FF;
auto &pressed = key_press[keyCode]; auto &pressed = key_press[keyCode];
@@ -600,31 +589,27 @@ void passthrough(std::shared_ptr<input_t> &input, PNV_MULTI_CONTROLLER_PACKET pa
void passthrough_helper(std::shared_ptr<input_t> input, std::vector<std::uint8_t> &&input_data) { void passthrough_helper(std::shared_ptr<input_t> input, std::vector<std::uint8_t> &&input_data) {
void *payload = input_data.data(); void *payload = input_data.data();
auto header = (PNV_INPUT_HEADER)payload;
int input_type = util::endian::big(*(int *)payload); switch(util::endian::little(header->magic)) {
case MOUSE_MOVE_REL_MAGIC_GEN5:
switch(input_type) {
case PACKET_TYPE_REL_MOUSE_MOVE:
passthrough(input, (PNV_REL_MOUSE_MOVE_PACKET)payload); passthrough(input, (PNV_REL_MOUSE_MOVE_PACKET)payload);
break; break;
case PACKET_TYPE_ABS_MOUSE_MOVE: case MOUSE_MOVE_ABS_MAGIC:
passthrough(input, (PNV_ABS_MOUSE_MOVE_PACKET)payload); passthrough(input, (PNV_ABS_MOUSE_MOVE_PACKET)payload);
break; break;
case PACKET_TYPE_MOUSE_BUTTON: case MOUSE_BUTTON_DOWN_EVENT_MAGIC_GEN5:
case MOUSE_BUTTON_UP_EVENT_MAGIC_GEN5:
passthrough(input, (PNV_MOUSE_BUTTON_PACKET)payload); passthrough(input, (PNV_MOUSE_BUTTON_PACKET)payload);
break; break;
case PACKET_TYPE_SCROLL_OR_KEYBOARD: { case SCROLL_MAGIC_GEN5:
char *tmp_input = (char *)payload + 4; passthrough((PNV_SCROLL_PACKET)payload);
if(tmp_input[0] == 0x0A) {
passthrough((PNV_SCROLL_PACKET)payload);
}
else {
passthrough(input, (PNV_KEYBOARD_PACKET)payload);
}
break; break;
} case KEY_DOWN_EVENT_MAGIC:
case PACKET_TYPE_MULTI_CONTROLLER: case KEY_UP_EVENT_MAGIC:
passthrough(input, (PNV_KEYBOARD_PACKET)payload);
break;
case MULTI_CONTROLLER_MAGIC_GEN5:
passthrough(input, (PNV_MULTI_CONTROLLER_PACKET)payload); passthrough(input, (PNV_MULTI_CONTROLLER_PACKET)payload);
break; break;
} }