C++程序  |  60行  |  1.71 KB

// Copyright (c) 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef ASH_DISPLAY_DISPLAY_PREF_UTIL_H
#define ASH_DISPLAY_DISPLAY_PREF_UTIL_H

#include <map>
#include <string>

#include "base/strings/string_piece.h"

namespace ash {

// Utility templates to create enum to string map and
// a function to find an enum value from a string.
template<typename T>
std::map<T, std::string>* CreateToStringMap(T k1, const std::string& v1,
                                            T k2, const std::string& v2,
                                            T k3, const std::string& v3,
                                            T k4, const std::string& v4) {
  std::map<T, std::string>* map = new std::map<T, std::string>();
  (*map)[k1] = v1;
  (*map)[k2] = v2;
  (*map)[k3] = v3;
  (*map)[k4] = v4;
  return map;
}

template<typename T>
std::map<T, std::string>* CreateToStringMap(T k1, const std::string& v1,
                                            T k2, const std::string& v2,
                                            T k3, const std::string& v3) {
  std::map<T, std::string>* map = new std::map<T, std::string>();
  (*map)[k1] = v1;
  (*map)[k2] = v2;
  (*map)[k3] = v3;
  return map;
}

template<typename T>
bool ReverseFind(const std::map<T, std::string>* map,
                 const base::StringPiece& value,
                 T* key) {
  typename std::map<T, std::string>::const_iterator iter = map->begin();
  for (;
       iter != map->end();
       ++iter) {
    if (iter->second == value) {
      *key = iter->first;
      return true;
    }
  }
  return false;
}

}  // namespace ash

#endif  // ASH_DISPLAY_DISPLAY_PREF_UTIL_H