format RegexCollection output using match results
This commit is contained in:
		
							parent
							
								
									7163752aa0
								
							
						
					
					
						commit
						76c2f3166e
					
				|  | @ -36,7 +36,7 @@ class RegexCollection { | |||
|   std::map<std::string, std::string> regex_cache; | ||||
|   std::string default_repr; | ||||
| 
 | ||||
|   std::string& find_match(std::string& value, bool& matched_any); | ||||
|   std::string find_match(std::string& value, bool& matched_any); | ||||
| 
 | ||||
|  public: | ||||
|   RegexCollection() = default; | ||||
|  | @ -48,4 +48,4 @@ class RegexCollection { | |||
|   std::string& get(std::string& value); | ||||
| }; | ||||
| 
 | ||||
| }  // namespace waybar::util
 | ||||
| }  // namespace waybar::util
 | ||||
|  |  | |||
|  | @ -31,11 +31,12 @@ RegexCollection::RegexCollection(const Json::Value& map, std::string default_rep | |||
|   std::sort(rules.begin(), rules.end(), [](Rule& a, Rule& b) { return a.priority > b.priority; }); | ||||
| } | ||||
| 
 | ||||
| std::string& RegexCollection::find_match(std::string& value, bool& matched_any) { | ||||
| std::string RegexCollection::find_match(std::string& value, bool& matched_any) { | ||||
|   for (auto& rule : rules) { | ||||
|     if (std::regex_search(value, rule.rule)) { | ||||
|     std::smatch match; | ||||
|     if (std::regex_search(value, match, rule.rule)) { | ||||
|       matched_any = true; | ||||
|       return rule.repr; | ||||
|       return match.format(rule.repr.data()); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue