hyprctl: Make device configs queryable (#3226)

* Make device configs queryable

Signed-off-by: pdamianik <39028343+pdamianik@users.noreply.github.com>

* Add set property to getoption output

---------

Signed-off-by: pdamianik <39028343+pdamianik@users.noreply.github.com>
This commit is contained in:
Philip Damianik 2023-09-09 13:25:17 +02:00 committed by GitHub
parent c061946a94
commit 1a6f961de2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 27 additions and 10 deletions

View File

@ -2015,20 +2015,36 @@ SConfigValue* CConfigManager::getConfigValuePtr(const std::string& val) {
}
SConfigValue* CConfigManager::getConfigValuePtrSafe(const std::string& val) {
const auto IT = configValues.find(val);
if (val.starts_with("device:")) {
const auto DEVICE = val.substr(7, val.find_last_of(':') - 7);
const auto CONFIGVAR = val.substr(val.find_last_of(':') + 1);
if (IT == configValues.end()) {
// maybe plugin
const auto DEVICECONF = deviceConfigs.find(DEVICE);
if (DEVICECONF == deviceConfigs.end())
return nullptr;
const auto IT = DEVICECONF->second.find(CONFIGVAR);
if (IT == DEVICECONF->second.end())
return nullptr;
return &IT->second;
} else if (val.starts_with("plugin:")) {
for (auto& [pl, pMap] : pluginConfigs) {
const auto PLIT = pMap->find(val);
const auto IT = pMap->find(val);
if (PLIT != pMap->end())
return &PLIT->second;
if (IT != pMap->end())
return &IT->second;
}
return nullptr;
}
const auto IT = configValues.find(val);
if (IT == configValues.end())
return nullptr;
return &(IT->second);
}

View File

@ -1039,8 +1039,8 @@ std::string dispatchGetOption(std::string request, HyprCtl::eHyprCtlOutputFormat
return "no such option";
if (format == HyprCtl::eHyprCtlOutputFormat::FORMAT_NORMAL)
return getFormat("option {}\n\tint: {}\n\tfloat: {:.5f}\n\tstr: \"{}\"\n\tdata: {:x}", curitem, PCFGOPT->intValue, PCFGOPT->floatValue, PCFGOPT->strValue,
(uintptr_t)PCFGOPT->data.get());
return getFormat("option {}\n\tint: {}\n\tfloat: {:.5f}\n\tstr: \"{}\"\n\tdata: {:x}\n\tset: {}", curitem, PCFGOPT->intValue, PCFGOPT->floatValue, PCFGOPT->strValue,
(uintptr_t)PCFGOPT->data.get(), PCFGOPT->set);
else {
return getFormat(
R"#(
@ -1049,10 +1049,11 @@ std::string dispatchGetOption(std::string request, HyprCtl::eHyprCtlOutputFormat
"int": {},
"float": {:.5f},
"str": "{}",
"data": "0x{:x}"
"data": "0x{:x}",
"set": {}
}}
)#",
curitem, PCFGOPT->intValue, PCFGOPT->floatValue, PCFGOPT->strValue, (uintptr_t)PCFGOPT->data.get());
curitem, PCFGOPT->intValue, PCFGOPT->floatValue, PCFGOPT->strValue, (uintptr_t)PCFGOPT->data.get(), PCFGOPT->set);
}
}