| OLD | NEW | 
|---|
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 #include "chrome/browser/resources_util.h" | 5 #include "chrome/browser/resources_util.h" | 
| 6 | 6 | 
| 7 #include <utility> | 7 #include <utility> | 
| 8 | 8 | 
| 9 #include "base/hash_tables.h" | 9 #include "base/hash_tables.h" | 
| 10 #include "base/lazy_instance.h" | 10 #include "base/lazy_instance.h" | 
| 11 #include "grit/theme_resources_map.h" | 11 #include "grit/theme_resources_map.h" | 
|  | 12 #include "grit/theme_resources_standard_map.h" | 
| 12 | 13 | 
| 13 namespace { | 14 namespace { | 
| 14 | 15 | 
| 15 // A wrapper class that holds a hash_map between resource strings and resource | 16 // A wrapper class that holds a hash_map between resource strings and resource | 
| 16 // ids.  This is done so we can use base::LazyInstance which takes care of | 17 // ids.  This is done so we can use base::LazyInstance which takes care of | 
| 17 // thread safety in initializing the hash_map for us. | 18 // thread safety in initializing the hash_map for us. | 
| 18 class ThemeMap { | 19 class ThemeMap { | 
| 19  public: | 20  public: | 
| 20   typedef base::hash_map<std::string, int> StringIntMap; | 21   typedef base::hash_map<std::string, int> StringIntMap; | 
| 21 | 22 | 
| 22   ThemeMap() { | 23   ThemeMap() { | 
| 23     for (size_t i = 0; i < kThemeResourcesSize; ++i) { | 24     for (size_t i = 0; i < kThemeResourcesSize; ++i) { | 
| 24       id_map_[kThemeResources[i].name] = kThemeResources[i].value; | 25       id_map_[kThemeResources[i].name] = kThemeResources[i].value; | 
| 25     } | 26     } | 
|  | 27     for (size_t i = 0; i < kThemeResourcesStandardSize; ++i) { | 
|  | 28       id_map_[kThemeResourcesStandard[i].name] = | 
|  | 29           kThemeResourcesStandard[i].value; | 
|  | 30     } | 
| 26   } | 31   } | 
| 27 | 32 | 
| 28   int GetId(const std::string& resource_name) { | 33   int GetId(const std::string& resource_name) { | 
| 29     StringIntMap::const_iterator it = id_map_.find(resource_name); | 34     StringIntMap::const_iterator it = id_map_.find(resource_name); | 
| 30     if (it == id_map_.end()) | 35     if (it == id_map_.end()) | 
| 31       return -1; | 36       return -1; | 
| 32     return it->second; | 37     return it->second; | 
| 33   } | 38   } | 
| 34 | 39 | 
| 35  private: | 40  private: | 
| 36   StringIntMap id_map_; | 41   StringIntMap id_map_; | 
| 37 }; | 42 }; | 
| 38 | 43 | 
| 39 static base::LazyInstance<ThemeMap> g_theme_ids(base::LINKER_INITIALIZED); | 44 static base::LazyInstance<ThemeMap> g_theme_ids(base::LINKER_INITIALIZED); | 
| 40 | 45 | 
| 41 }  // namespace | 46 }  // namespace | 
| 42 | 47 | 
| 43 int ResourcesUtil::GetThemeResourceId(const std::string& resource_name) { | 48 int ResourcesUtil::GetThemeResourceId(const std::string& resource_name) { | 
| 44   return g_theme_ids.Get().GetId(resource_name); | 49   return g_theme_ids.Get().GetId(resource_name); | 
| 45 } | 50 } | 
| OLD | NEW | 
|---|