mirror of
https://github.com/CalcProgrammer1/OpenRGB.git
synced 2026-05-16 18:44:53 -04:00
Store name in CherryKeyboardController to avoid setting it in detector
This commit is contained in:
@@ -13,10 +13,11 @@
|
||||
#include "CherryKeyboardController.h"
|
||||
#include "StringUtils.h"
|
||||
|
||||
CherryKeyboardController::CherryKeyboardController(hid_device* dev_handle, const char* path)
|
||||
CherryKeyboardController::CherryKeyboardController(hid_device* dev_handle, const char* path, std::string dev_name)
|
||||
{
|
||||
dev = dev_handle;
|
||||
location = path;
|
||||
name = dev_name;
|
||||
}
|
||||
|
||||
CherryKeyboardController::~CherryKeyboardController()
|
||||
@@ -29,6 +30,11 @@ std::string CherryKeyboardController::GetDeviceLocation()
|
||||
return("HID: " + location);
|
||||
}
|
||||
|
||||
std::string CherryKeyboardController::GetDeviceName()
|
||||
{
|
||||
return(name);
|
||||
}
|
||||
|
||||
std::string CherryKeyboardController::GetSerialString()
|
||||
{
|
||||
wchar_t serial_string[128];
|
||||
|
||||
@@ -124,10 +124,11 @@ enum
|
||||
class CherryKeyboardController
|
||||
{
|
||||
public:
|
||||
CherryKeyboardController(hid_device* dev_handle, const char* path);
|
||||
CherryKeyboardController(hid_device* dev_handle, const char* path, std::string dev_name);
|
||||
~CherryKeyboardController();
|
||||
|
||||
std::string GetDeviceLocation();
|
||||
std::string GetDeviceName();
|
||||
std::string GetSerialString();
|
||||
|
||||
void SetKeyboardColors
|
||||
@@ -167,6 +168,7 @@ public:
|
||||
private:
|
||||
hid_device* dev;
|
||||
std::string location;
|
||||
std::string name;
|
||||
|
||||
void ComputeChecksum
|
||||
(
|
||||
|
||||
@@ -33,9 +33,9 @@ void DetectCherryKeyboards(hid_device_info* info, const std::string& name)
|
||||
hid_device* dev = hid_open_path(info->path);
|
||||
if( dev )
|
||||
{
|
||||
CherryKeyboardController* controller = new CherryKeyboardController(dev, info->path);
|
||||
CherryKeyboardController* controller = new CherryKeyboardController(dev, info->path, name);
|
||||
RGBController_CherryKeyboard* rgb_controller = new RGBController_CherryKeyboard(controller, info->product_id);
|
||||
rgb_controller->name = name;
|
||||
|
||||
ResourceManager::get()->RegisterRGBController(rgb_controller);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -43,7 +43,7 @@ RGBController_CherryKeyboard::RGBController_CherryKeyboard(CherryKeyboardControl
|
||||
{
|
||||
controller = controller_ptr;
|
||||
|
||||
name = "Cherry Keyboard Device";
|
||||
name = controller->GetDeviceName();
|
||||
vendor = "Cherry";
|
||||
type = DEVICE_TYPE_KEYBOARD;
|
||||
description = "Cherry Keyboard Device";
|
||||
|
||||
Reference in New Issue
Block a user