mirror of
https://github.com/NixOS/nix.git
synced 2025-11-16 23:42:43 +01:00
More flexible typing for get in util.hh
This is good for e.g. `std::string_view` and `StringMap`. Needed by #11139 Co-authored-by: Sergei Zimmerman <145775305+xokdvium@users.noreply.github.com>
This commit is contained in:
parent
22378ea093
commit
0ef818dd92
1 changed files with 6 additions and 7 deletions
|
|
@ -196,8 +196,8 @@ std::pair<std::string_view, std::string_view> getLine(std::string_view s);
|
|||
/**
|
||||
* Get a value for the specified key from an associate container.
|
||||
*/
|
||||
template<class T>
|
||||
const typename T::mapped_type * get(const T & map, const typename T::key_type & key)
|
||||
template<class T, typename K>
|
||||
const typename T::mapped_type * get(const T & map, K & key)
|
||||
{
|
||||
auto i = map.find(key);
|
||||
if (i == map.end())
|
||||
|
|
@ -205,8 +205,8 @@ const typename T::mapped_type * get(const T & map, const typename T::key_type &
|
|||
return &i->second;
|
||||
}
|
||||
|
||||
template<class T>
|
||||
typename T::mapped_type * get(T & map, const typename T::key_type & key)
|
||||
template<class T, typename K>
|
||||
typename T::mapped_type * get(T & map, K & key)
|
||||
{
|
||||
auto i = map.find(key);
|
||||
if (i == map.end())
|
||||
|
|
@ -221,9 +221,8 @@ typename T::mapped_type * get(T && map, const typename T::key_type & key) = dele
|
|||
/**
|
||||
* Get a value for the specified key from an associate container, or a default value if the key isn't present.
|
||||
*/
|
||||
template<class T>
|
||||
const typename T::mapped_type &
|
||||
getOr(T & map, const typename T::key_type & key, const typename T::mapped_type & defaultValue)
|
||||
template<class T, typename K>
|
||||
const typename T::mapped_type & getOr(T & map, K & key, const typename T::mapped_type & defaultValue)
|
||||
{
|
||||
auto i = map.find(key);
|
||||
if (i == map.end())
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue