| Index: components/os_crypt/libsecret_util_posix.cc | 
| diff --git a/components/os_crypt/libsecret_util_posix.cc b/components/os_crypt/libsecret_util_posix.cc | 
| deleted file mode 100644 | 
| index 58ba9d0518aa4495a097fe4cba51de127d5a09ff..0000000000000000000000000000000000000000 | 
| --- a/components/os_crypt/libsecret_util_posix.cc | 
| +++ /dev/null | 
| @@ -1,134 +0,0 @@ | 
| -// Copyright 2016 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. | 
| - | 
| -#include "components/os_crypt/libsecret_util_posix.h" | 
| - | 
| -#include <dlfcn.h> | 
| - | 
| -#include "base/logging.h" | 
| -#include "base/strings/string_number_conversions.h" | 
| - | 
| -decltype( | 
| -    &::secret_password_store_sync) LibsecretLoader::secret_password_store_sync; | 
| -decltype( | 
| -    &::secret_service_search_sync) LibsecretLoader::secret_service_search_sync; | 
| -decltype( | 
| -    &::secret_password_clear_sync) LibsecretLoader::secret_password_clear_sync; | 
| -decltype(&::secret_item_get_secret) LibsecretLoader::secret_item_get_secret; | 
| -decltype(&::secret_value_get_text) LibsecretLoader::secret_value_get_text; | 
| -decltype( | 
| -    &::secret_item_get_attributes) LibsecretLoader::secret_item_get_attributes; | 
| -decltype(&::secret_item_load_secret_sync) | 
| -    LibsecretLoader::secret_item_load_secret_sync; | 
| -decltype(&::secret_value_unref) LibsecretLoader::secret_value_unref; | 
| - | 
| -bool LibsecretLoader::libsecret_loaded_ = false; | 
| - | 
| -const LibsecretLoader::FunctionInfo LibsecretLoader::kFunctions[] = { | 
| -    {"secret_password_store_sync", | 
| -     reinterpret_cast<void**>(&secret_password_store_sync)}, | 
| -    {"secret_service_search_sync", | 
| -     reinterpret_cast<void**>(&secret_service_search_sync)}, | 
| -    {"secret_password_clear_sync", | 
| -     reinterpret_cast<void**>(&secret_password_clear_sync)}, | 
| -    {"secret_item_get_secret", | 
| -     reinterpret_cast<void**>(&secret_item_get_secret)}, | 
| -    {"secret_value_get_text", reinterpret_cast<void**>(&secret_value_get_text)}, | 
| -    {"secret_item_get_attributes", | 
| -     reinterpret_cast<void**>(&secret_item_get_attributes)}, | 
| -    {"secret_item_load_secret_sync", | 
| -     reinterpret_cast<void**>(&secret_item_load_secret_sync)}, | 
| -    {"secret_value_unref", reinterpret_cast<void**>(&secret_value_unref)}}; | 
| - | 
| -// static | 
| -bool LibsecretLoader::EnsureLibsecretLoaded() { | 
| -  return LoadLibsecret() && LibsecretIsAvailable(); | 
| -} | 
| - | 
| -// static | 
| -bool LibsecretLoader::LoadLibsecret() { | 
| -  if (libsecret_loaded_) | 
| -    return true; | 
| - | 
| -  void* handle = dlopen("libsecret-1.so.0", RTLD_NOW | RTLD_GLOBAL); | 
| -  if (!handle) { | 
| -    // We wanted to use libsecret, but we couldn't load it. Warn, because | 
| -    // either the user asked for this, or we autodetected it incorrectly. (Or | 
| -    // the system has broken libraries, which is also good to warn about.) | 
| -    // TODO(crbug.com/607435): Channel this message to the user-facing log | 
| -    VLOG(1) << "Could not load libsecret-1.so.0: " << dlerror(); | 
| -    return false; | 
| -  } | 
| - | 
| -  for (const auto& function : kFunctions) { | 
| -    dlerror(); | 
| -    *function.pointer = dlsym(handle, function.name); | 
| -    const char* error = dlerror(); | 
| -    if (error) { | 
| -      VLOG(1) << "Unable to load symbol " << function.name << ": " << error; | 
| -      dlclose(handle); | 
| -      return false; | 
| -    } | 
| -  } | 
| - | 
| -  libsecret_loaded_ = true; | 
| -  // We leak the library handle. That's OK: this function is called only once. | 
| -  return true; | 
| -} | 
| - | 
| -// static | 
| -bool LibsecretLoader::LibsecretIsAvailable() { | 
| -  if (!libsecret_loaded_) | 
| -    return false; | 
| -  // A dummy query is made to check for availability, because libsecret doesn't | 
| -  // have a dedicated availability function. For performance reasons, the query | 
| -  // is meant to return an empty result. | 
| -  LibsecretAttributesBuilder attrs; | 
| -  attrs.Append("application", "chrome-string_to_get_empty_result"); | 
| -  const SecretSchema kDummySchema = { | 
| -      "_chrome_dummy_schema", | 
| -      SECRET_SCHEMA_DONT_MATCH_NAME, | 
| -      {{"application", SECRET_SCHEMA_ATTRIBUTE_STRING}, | 
| -       {nullptr, SECRET_SCHEMA_ATTRIBUTE_STRING}}}; | 
| - | 
| -  GError* error = nullptr; | 
| -  GList* found = | 
| -      secret_service_search_sync(nullptr,  // default secret service | 
| -                                 &kDummySchema, attrs.Get(), SECRET_SEARCH_ALL, | 
| -                                 nullptr,  // no cancellable ojbect | 
| -                                 &error); | 
| -  bool success = (error == nullptr); | 
| -  if (error) | 
| -    g_error_free(error); | 
| -  if (found) | 
| -    g_list_free(found); | 
| - | 
| -  return success; | 
| -} | 
| - | 
| -LibsecretAttributesBuilder::LibsecretAttributesBuilder() { | 
| -  attrs_ = g_hash_table_new_full(g_str_hash, g_str_equal, | 
| -                                 nullptr,   // no deleter for keys | 
| -                                 nullptr);  // no deleter for values | 
| -} | 
| - | 
| -LibsecretAttributesBuilder::~LibsecretAttributesBuilder() { | 
| -  g_hash_table_destroy(attrs_); | 
| -} | 
| - | 
| -void LibsecretAttributesBuilder::Append(const std::string& name, | 
| -                                        const std::string& value) { | 
| -  name_values_.push_back(name); | 
| -  gpointer name_str = | 
| -      static_cast<gpointer>(const_cast<char*>(name_values_.back().c_str())); | 
| -  name_values_.push_back(value); | 
| -  gpointer value_str = | 
| -      static_cast<gpointer>(const_cast<char*>(name_values_.back().c_str())); | 
| -  g_hash_table_insert(attrs_, name_str, value_str); | 
| -} | 
| - | 
| -void LibsecretAttributesBuilder::Append(const std::string& name, | 
| -                                        int64_t value) { | 
| -  Append(name, base::Int64ToString(value)); | 
| -} | 
|  |