| 
									
										
											  
											
												chore: make yuzu REUSE compliant
[REUSE] is a specification that aims at making file copyright
information consistent, so that it can be both human and machine
readable. It basically requires that all files have a header containing
copyright and licensing information. When this isn't possible, like
when dealing with binary assets, generated files or embedded third-party
dependencies, it is permitted to insert copyright information in the
`.reuse/dep5` file.
Oh, and it also requires that all the licenses used in the project are
present in the `LICENSES` folder, that's why the diff is so huge.
This can be done automatically with `reuse download --all`.
The `reuse` tool also contains a handy subcommand that analyzes the
project and tells whether or not the project is (still) compliant,
`reuse lint`.
Following REUSE has a few advantages over the current approach:
- Copyright information is easy to access for users / downstream
- Files like `dist/license.md` do not need to exist anymore, as
  `.reuse/dep5` is used instead
- `reuse lint` makes it easy to ensure that copyright information of
  files like binary assets / images is always accurate and up to date
To add copyright information of files that didn't have it I looked up
who committed what and when, for each file. As yuzu contributors do not
have to sign a CLA or similar I couldn't assume that copyright ownership
was of the "yuzu Emulator Project", so I used the name and/or email of
the commit author instead.
[REUSE]: https://reuse.software
Follow-up to 01cf05bc75b1e47beb08937439f3ed9339e7b254
											
										 
											2022-05-15 02:06:02 +02:00
										 |  |  | // SPDX-FileCopyrightText: 2018 Citra Emulator Project
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: GPL-2.0-or-later
 | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <array>
 | 
					
						
							|  |  |  | #include <optional>
 | 
					
						
							|  |  |  | #include <type_traits>
 | 
					
						
							| 
									
										
										
										
											2020-11-15 06:22:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-20 18:20:46 -05:00
										 |  |  | #ifdef _MSC_VER
 | 
					
						
							|  |  |  | #pragma warning(push)
 | 
					
						
							|  |  |  | #pragma warning(disable : 4701) // Potentially uninitialized local variable 'result' used
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | #include <boost/crc.hpp>
 | 
					
						
							| 
									
										
										
										
											2020-11-15 06:22:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-20 18:20:46 -05:00
										 |  |  | #ifdef _MSC_VER
 | 
					
						
							|  |  |  | #pragma warning(pop)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | #include "common/swap.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace InputCommon::CemuhookUDP { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | constexpr std::size_t MAX_PACKET_SIZE = 100; | 
					
						
							|  |  |  | constexpr u16 PROTOCOL_VERSION = 1001; | 
					
						
							|  |  |  | constexpr u32 CLIENT_MAGIC = 0x43555344; // DSUC (but flipped for LE)
 | 
					
						
							|  |  |  | constexpr u32 SERVER_MAGIC = 0x53555344; // DSUS (but flipped for LE)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum class Type : u32 { | 
					
						
							|  |  |  |     Version = 0x00100000, | 
					
						
							|  |  |  |     PortInfo = 0x00100001, | 
					
						
							|  |  |  |     PadData = 0x00100002, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct Header { | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |     u32_le magic{}; | 
					
						
							|  |  |  |     u16_le protocol_version{}; | 
					
						
							|  |  |  |     u16_le payload_length{}; | 
					
						
							|  |  |  |     u32_le crc{}; | 
					
						
							|  |  |  |     u32_le id{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |     ///> In the protocol, the type of the packet is not part of the header, but its convenient to
 | 
					
						
							|  |  |  |     ///> include in the header so the callee doesn't have to duplicate the type twice when building
 | 
					
						
							|  |  |  |     ///> the data
 | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |     Type type{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | static_assert(sizeof(Header) == 20, "UDP Message Header struct has wrong size"); | 
					
						
							|  |  |  | static_assert(std::is_trivially_copyable_v<Header>, "UDP Message Header is not trivially copyable"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | using MacAddress = std::array<u8, 6>; | 
					
						
							|  |  |  | constexpr MacAddress EMPTY_MAC_ADDRESS = {0, 0, 0, 0, 0, 0}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma pack(push, 1)
 | 
					
						
							|  |  |  | template <typename T> | 
					
						
							|  |  |  | struct Message { | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |     Header header{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |     T data; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | #pragma pack(pop)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | template <typename T> | 
					
						
							|  |  |  | constexpr Type GetMessageType(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-07 14:56:33 +02:00
										 |  |  | template <typename T> | 
					
						
							|  |  |  | Message<T> CreateMessage(const u32 magic, const T data, const u32 sender_id) { | 
					
						
							|  |  |  |     boost::crc_32_type crc; | 
					
						
							|  |  |  |     Header header{ | 
					
						
							|  |  |  |         magic, PROTOCOL_VERSION, sizeof(T) + sizeof(Type), 0, sender_id, GetMessageType<T>(), | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     Message<T> message{header, data}; | 
					
						
							|  |  |  |     crc.process_bytes(&message, sizeof(Message<T>)); | 
					
						
							|  |  |  |     message.header.crc = crc.checksum(); | 
					
						
							|  |  |  |     return message; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | namespace Request { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-26 15:45:37 -06:00
										 |  |  | enum RegisterFlags : u8 { | 
					
						
							|  |  |  |     AllPads, | 
					
						
							|  |  |  |     PadID, | 
					
						
							|  |  |  |     PadMACAdddress, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | struct Version {}; | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Requests the server to send information about what controllers are plugged into the ports | 
					
						
							| 
									
										
										
										
											2022-07-15 19:45:35 +02:00
										 |  |  |  * In yuzu's case, we only have one controller, so for simplicity's sake, we can just send a | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |  * request explicitly for the first controller port and leave it at that. In the future it would be | 
					
						
							|  |  |  |  * nice to make this configurable | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | constexpr u32 MAX_PORTS = 4; | 
					
						
							|  |  |  | struct PortInfo { | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |     u32_le pad_count{}; ///> Number of ports to request data for
 | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |     std::array<u8, MAX_PORTS> port; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | static_assert(std::is_trivially_copyable_v<PortInfo>, | 
					
						
							|  |  |  |               "UDP Request PortInfo is not trivially copyable"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Request the latest pad information from the server. If the server hasn't received this message | 
					
						
							|  |  |  |  * from the client in a reasonable time frame, the server will stop sending updates. The default | 
					
						
							|  |  |  |  * timeout seems to be 5 seconds. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct PadData { | 
					
						
							|  |  |  |     /// Determines which method will be used as a look up for the controller
 | 
					
						
							| 
									
										
										
										
											2021-11-26 15:45:37 -06:00
										 |  |  |     RegisterFlags flags{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |     /// Index of the port of the controller to retrieve data about
 | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |     u8 port_id{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |     /// Mac address of the controller to retrieve data about
 | 
					
						
							|  |  |  |     MacAddress mac; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | static_assert(sizeof(PadData) == 8, "UDP Request PadData struct has wrong size"); | 
					
						
							|  |  |  | static_assert(std::is_trivially_copyable_v<PadData>, | 
					
						
							|  |  |  |               "UDP Request PadData is not trivially copyable"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Creates a message with the proper header data that can be sent to the server. | 
					
						
							| 
									
										
										
										
											2020-11-15 06:22:01 -05:00
										 |  |  |  * @param data Request body to send | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |  * @param client_id ID of the udp client (usually not checked on the server) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | template <typename T> | 
					
						
							|  |  |  | Message<T> Create(const T data, const u32 client_id = 0) { | 
					
						
							| 
									
										
										
										
											2021-11-07 14:56:33 +02:00
										 |  |  |     return CreateMessage(CLIENT_MAGIC, data, client_id); | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | } | 
					
						
							|  |  |  | } // namespace Request
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Response { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-26 15:45:37 -06:00
										 |  |  | enum class ConnectionType : u8 { | 
					
						
							|  |  |  |     None, | 
					
						
							|  |  |  |     Usb, | 
					
						
							|  |  |  |     Bluetooth, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum class State : u8 { | 
					
						
							|  |  |  |     Disconnected, | 
					
						
							|  |  |  |     Reserved, | 
					
						
							|  |  |  |     Connected, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum class Model : u8 { | 
					
						
							|  |  |  |     None, | 
					
						
							|  |  |  |     PartialGyro, | 
					
						
							|  |  |  |     FullGyro, | 
					
						
							|  |  |  |     Generic, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum class Battery : u8 { | 
					
						
							|  |  |  |     None = 0x00, | 
					
						
							|  |  |  |     Dying = 0x01, | 
					
						
							|  |  |  |     Low = 0x02, | 
					
						
							|  |  |  |     Medium = 0x03, | 
					
						
							|  |  |  |     High = 0x04, | 
					
						
							|  |  |  |     Full = 0x05, | 
					
						
							|  |  |  |     Charging = 0xEE, | 
					
						
							|  |  |  |     Charged = 0xEF, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | struct Version { | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |     u16_le version{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | static_assert(sizeof(Version) == 2, "UDP Response Version struct has wrong size"); | 
					
						
							|  |  |  | static_assert(std::is_trivially_copyable_v<Version>, | 
					
						
							|  |  |  |               "UDP Response Version is not trivially copyable"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct PortInfo { | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |     u8 id{}; | 
					
						
							| 
									
										
										
										
											2021-11-26 15:45:37 -06:00
										 |  |  |     State state{}; | 
					
						
							|  |  |  |     Model model{}; | 
					
						
							|  |  |  |     ConnectionType connection_type{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |     MacAddress mac; | 
					
						
							| 
									
										
										
										
											2021-11-26 15:45:37 -06:00
										 |  |  |     Battery battery{}; | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |     u8 is_pad_active{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | static_assert(sizeof(PortInfo) == 12, "UDP Response PortInfo struct has wrong size"); | 
					
						
							|  |  |  | static_assert(std::is_trivially_copyable_v<PortInfo>, | 
					
						
							|  |  |  |               "UDP Response PortInfo is not trivially copyable"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-01 12:32:29 -06:00
										 |  |  | struct TouchPad { | 
					
						
							|  |  |  |     u8 is_active{}; | 
					
						
							|  |  |  |     u8 id{}; | 
					
						
							|  |  |  |     u16_le x{}; | 
					
						
							|  |  |  |     u16_le y{}; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | static_assert(sizeof(TouchPad) == 6, "UDP Response TouchPad struct has wrong size "); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | #pragma pack(push, 1)
 | 
					
						
							|  |  |  | struct PadData { | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |     PortInfo info{}; | 
					
						
							|  |  |  |     u32_le packet_counter{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |     u16_le digital_button{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |     // The following union isn't trivially copyable but we don't use this input anyway.
 | 
					
						
							|  |  |  |     // union DigitalButton {
 | 
					
						
							|  |  |  |     //     u16_le button;
 | 
					
						
							|  |  |  |     //     BitField<0, 1, u16> button_1;   // Share
 | 
					
						
							|  |  |  |     //     BitField<1, 1, u16> button_2;   // L3
 | 
					
						
							|  |  |  |     //     BitField<2, 1, u16> button_3;   // R3
 | 
					
						
							|  |  |  |     //     BitField<3, 1, u16> button_4;   // Options
 | 
					
						
							|  |  |  |     //     BitField<4, 1, u16> button_5;   // Up
 | 
					
						
							|  |  |  |     //     BitField<5, 1, u16> button_6;   // Right
 | 
					
						
							|  |  |  |     //     BitField<6, 1, u16> button_7;   // Down
 | 
					
						
							|  |  |  |     //     BitField<7, 1, u16> button_8;   // Left
 | 
					
						
							|  |  |  |     //     BitField<8, 1, u16> button_9;   // L2
 | 
					
						
							|  |  |  |     //     BitField<9, 1, u16> button_10;  // R2
 | 
					
						
							|  |  |  |     //     BitField<10, 1, u16> button_11; // L1
 | 
					
						
							|  |  |  |     //     BitField<11, 1, u16> button_12; // R1
 | 
					
						
							|  |  |  |     //     BitField<12, 1, u16> button_13; // Triangle
 | 
					
						
							|  |  |  |     //     BitField<13, 1, u16> button_14; // Circle
 | 
					
						
							|  |  |  |     //     BitField<14, 1, u16> button_15; // Cross
 | 
					
						
							|  |  |  |     //     BitField<15, 1, u16> button_16; // Square
 | 
					
						
							|  |  |  |     // } digital_button;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     u8 home; | 
					
						
							|  |  |  |     /// If the device supports a "click" on the touchpad, this will change to 1 when a click happens
 | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |     u8 touch_hard_press{}; | 
					
						
							|  |  |  |     u8 left_stick_x{}; | 
					
						
							|  |  |  |     u8 left_stick_y{}; | 
					
						
							|  |  |  |     u8 right_stick_x{}; | 
					
						
							|  |  |  |     u8 right_stick_y{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     struct AnalogButton { | 
					
						
							| 
									
										
										
										
											2021-11-26 15:45:37 -06:00
										 |  |  |         u8 button_dpad_left_analog{}; | 
					
						
							|  |  |  |         u8 button_dpad_down_analog{}; | 
					
						
							|  |  |  |         u8 button_dpad_right_analog{}; | 
					
						
							|  |  |  |         u8 button_dpad_up_analog{}; | 
					
						
							|  |  |  |         u8 button_square_analog{}; | 
					
						
							|  |  |  |         u8 button_cross_analog{}; | 
					
						
							|  |  |  |         u8 button_circle_analog{}; | 
					
						
							|  |  |  |         u8 button_triangle_analog{}; | 
					
						
							|  |  |  |         u8 button_r1_analog{}; | 
					
						
							|  |  |  |         u8 button_l1_analog{}; | 
					
						
							|  |  |  |         u8 trigger_r2{}; | 
					
						
							|  |  |  |         u8 trigger_l2{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |     } analog_button; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-01 12:32:29 -06:00
										 |  |  |     std::array<TouchPad, 2> touch; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     u64_le motion_timestamp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct Accelerometer { | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |         float x{}; | 
					
						
							|  |  |  |         float y{}; | 
					
						
							|  |  |  |         float z{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |     } accel; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct Gyroscope { | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  |         float pitch{}; | 
					
						
							|  |  |  |         float yaw{}; | 
					
						
							|  |  |  |         float roll{}; | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  |     } gyro; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | #pragma pack(pop)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static_assert(sizeof(PadData) == 80, "UDP Response PadData struct has wrong size "); | 
					
						
							|  |  |  | static_assert(std::is_trivially_copyable_v<PadData>, | 
					
						
							|  |  |  |               "UDP Response PadData is not trivially copyable"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static_assert(sizeof(Message<PadData>) == MAX_PACKET_SIZE, | 
					
						
							|  |  |  |               "UDP MAX_PACKET_SIZE is no longer larger than Message<PadData>"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 07:04:28 +01:00
										 |  |  | static_assert(sizeof(PadData::AnalogButton) == 12, | 
					
						
							|  |  |  |               "UDP Response AnalogButton struct has wrong size "); | 
					
						
							|  |  |  | static_assert(sizeof(PadData::Accelerometer) == 12, | 
					
						
							|  |  |  |               "UDP Response Accelerometer struct has wrong size "); | 
					
						
							|  |  |  | static_assert(sizeof(PadData::Gyroscope) == 12, "UDP Response Gyroscope struct has wrong size "); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 15:57:49 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Create a Response Message from the data | 
					
						
							|  |  |  |  * @param data array of bytes sent from the server | 
					
						
							|  |  |  |  * @return boost::none if it failed to parse or Type if it succeeded. The client can then safely | 
					
						
							|  |  |  |  * copy the data into the appropriate struct for that Type | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | std::optional<Type> Validate(u8* data, std::size_t size); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace Response
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | template <> | 
					
						
							|  |  |  | constexpr Type GetMessageType<Request::Version>() { | 
					
						
							|  |  |  |     return Type::Version; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | template <> | 
					
						
							|  |  |  | constexpr Type GetMessageType<Request::PortInfo>() { | 
					
						
							|  |  |  |     return Type::PortInfo; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | template <> | 
					
						
							|  |  |  | constexpr Type GetMessageType<Request::PadData>() { | 
					
						
							|  |  |  |     return Type::PadData; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | template <> | 
					
						
							|  |  |  | constexpr Type GetMessageType<Response::Version>() { | 
					
						
							|  |  |  |     return Type::Version; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | template <> | 
					
						
							|  |  |  | constexpr Type GetMessageType<Response::PortInfo>() { | 
					
						
							|  |  |  |     return Type::PortInfo; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | template <> | 
					
						
							|  |  |  | constexpr Type GetMessageType<Response::PadData>() { | 
					
						
							|  |  |  |     return Type::PadData; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | } // namespace InputCommon::CemuhookUDP
 |