33 std::vector<std::string> digestNameValuePairs;
36 for (
const auto &digestNameValue : digestNameValuePairs) {
37 std::string_view digestNameValueSV {digestNameValue};
38 auto equalPos = digestNameValueSV.find(
'=');
39 if (equalPos == std::string_view::npos || equalPos >= digestNameValueSV.size() - 1)
42 std::string_view cksumTypeSV = digestNameValueSV.substr(0, equalPos);
44 if (cksumTypeSV.empty())
47 std::string_view cksumValueInSV = digestNameValueSV.substr(equalPos + 1);
48 size_t beginCksumPos = cksumValueInSV.find(
':');
49 size_t endCksumPos = cksumValueInSV.rfind(
':');
52 if (beginCksumPos == 0 && endCksumPos > beginCksumPos + 1 && endCksumPos < cksumValueInSV.size()) {
53 std::string_view cksumValue = cksumValueInSV.substr(beginCksumPos + 1, endCksumPos - beginCksumPos - 1);
55 if (!cksumValue.empty()) {
58 std::string chksumDecoded;
60 std::string cksumTypeLC {cksumTypeSV};
61 std::transform(cksumTypeLC.begin(), cksumTypeLC.end(), cksumTypeLC.begin(), ::tolower);
62 output[cksumTypeLC] = chksumDecoded;
71 std::string_view value_sv {value};
72 while(pos <= value_sv.size()) {
74 size_t comma = value.find(
',',pos);
76 std::string_view item = (comma == std::string_view::npos) ? value_sv.substr(pos) : value_sv.substr(pos, comma - pos);
78 pos = (comma == std::string_view::npos) ? value.size() + 1 : comma + 1;
81 if(item.empty())
continue;
83 size_t eq = item.find(
'=');
85 if(eq == std::string_view::npos)
continue;
87 std::string_view digestName {item.substr(0, eq)};
89 std::string_view preference {item.substr(eq+1)};
92 std::string key_lower {digestName};
93 std::transform(key_lower.begin(),key_lower.end(),key_lower.begin(),::tolower);
98 preference_us = std::min(preference_us,(uint8_t)10);
99 output[key_lower] = preference_us;