 Chromium Code Reviews
 Chromium Code Reviews Issue 2104653002:
  Fix content shell layout test failure related to Fontconfig  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master
    
  
    Issue 2104653002:
  Fix content shell layout test failure related to Fontconfig  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master| OLD | NEW | 
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "ui/gfx/test/fontconfig_util_linux.h" | 5 #include "ui/gfx/test/fontconfig_util_linux.h" | 
| 6 | 6 | 
| 7 #include <fontconfig/fontconfig.h> | 7 #include <fontconfig/fontconfig.h> | 
| 8 | 8 | 
| 9 #include "base/files/file_util.h" | 9 #include "base/files/file_util.h" | 
| 10 #include "base/logging.h" | 10 #include "base/logging.h" | 
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 57 const char kFontconfigFileHeader[] = | 57 const char kFontconfigFileHeader[] = | 
| 58 "<?xml version=\"1.0\"?>\n" | 58 "<?xml version=\"1.0\"?>\n" | 
| 59 "<!DOCTYPE fontconfig SYSTEM \"fonts.dtd\">\n" | 59 "<!DOCTYPE fontconfig SYSTEM \"fonts.dtd\">\n" | 
| 60 "<fontconfig>\n"; | 60 "<fontconfig>\n"; | 
| 61 const char kFontconfigFileFooter[] = "</fontconfig>"; | 61 const char kFontconfigFileFooter[] = "</fontconfig>"; | 
| 62 const char kFontconfigMatchFontHeader[] = " <match target=\"font\">\n"; | 62 const char kFontconfigMatchFontHeader[] = " <match target=\"font\">\n"; | 
| 63 const char kFontconfigMatchPatternHeader[] = " <match target=\"pattern\">\n"; | 63 const char kFontconfigMatchPatternHeader[] = " <match target=\"pattern\">\n"; | 
| 64 const char kFontconfigMatchFooter[] = " </match>\n"; | 64 const char kFontconfigMatchFooter[] = " </match>\n"; | 
| 65 | 65 | 
| 66 void SetUpFontconfig() { | 66 void SetUpFontconfig() { | 
| 67 FcInit(); | 67 CHECK(FcInit()); | 
| 68 | 68 CHECK(FcConfigGetCurrent()); | 
| 
Daniel Erat
2016/06/27 22:40:15
i think that the reason for the old code was to st
 | |
| 69 // A primer on undocumented FcConfig reference-counting: | |
| 70 // | |
| 71 // - FcConfigCreate() creates a config with a refcount of 1. | |
| 72 // - FcConfigReference() increments a config's refcount. | |
| 73 // - FcConfigDestroy() decrements a config's refcount, deallocating the | |
| 74 // config when the count reaches 0. | |
| 75 // - FcConfigSetCurrent() calls FcConfigDestroy() on the old config, but | |
| 76 // interestingly does not call FcConfigReference() on the new config. | |
| 77 CHECK(FcConfigSetCurrent(FcConfigCreate())); | |
| 78 } | 69 } | 
| 79 | 70 | 
| 80 void TearDownFontconfig() { | 71 void TearDownFontconfig() { | 
| 81 FcFini(); | 72 FcFini(); | 
| 82 } | 73 } | 
| 83 | 74 | 
| 84 bool LoadFontIntoFontconfig(const base::FilePath& path) { | 75 bool LoadFontIntoFontconfig(const base::FilePath& path) { | 
| 85 if (!base::PathExists(path)) { | 76 if (!base::PathExists(path)) { | 
| 86 LOG(ERROR) << "You are missing " << path.value() << ". Try re-running " | 77 LOG(ERROR) << "You are missing " << path.value() << ". Try re-running " | 
| 87 << "build/install-build-deps.sh. Also see " | 78 << "build/install-build-deps.sh. Also see " | 
| (...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 159 const std::string& preferred_family) { | 150 const std::string& preferred_family) { | 
| 160 return base::StringPrintf( | 151 return base::StringPrintf( | 
| 161 " <alias>\n" | 152 " <alias>\n" | 
| 162 " <family>%s</family>\n" | 153 " <family>%s</family>\n" | 
| 163 " <prefer><family>%s</family></prefer>\n" | 154 " <prefer><family>%s</family></prefer>\n" | 
| 164 " </alias>\n", | 155 " </alias>\n", | 
| 165 original_family.c_str(), preferred_family.c_str()); | 156 original_family.c_str(), preferred_family.c_str()); | 
| 166 } | 157 } | 
| 167 | 158 | 
| 168 } // namespace gfx | 159 } // namespace gfx | 
| OLD | NEW |