| Index: content/browser/storage_partition_impl_map.h
|
| diff --git a/content/browser/storage_partition_impl_map.h b/content/browser/storage_partition_impl_map.h
|
| index 14b78ceebb78938298a3d7032088ff6683fa0a0b..9da35c304aa0e76f4c4e0bfd34322ee947973715 100644
|
| --- a/content/browser/storage_partition_impl_map.h
|
| +++ b/content/browser/storage_partition_impl_map.h
|
| @@ -9,6 +9,7 @@
|
| #include <string>
|
|
|
| #include "base/callback_forward.h"
|
| +#include "base/gtest_prod_util.h"
|
| #include "base/supports_user_data.h"
|
| #include "content/browser/storage_partition_impl.h"
|
| #include "content/public/browser/browser_context.h"
|
| @@ -34,11 +35,58 @@ class StoragePartitionImplMap : public base::SupportsUserData::Data {
|
| void ForEach(const BrowserContext::StoragePartitionCallback& callback);
|
|
|
| private:
|
| - typedef std::map<StoragePartitionImpl::StoragePartitionConfig,
|
| + FRIEND_TEST_ALL_PREFIXES(StoragePartitionConfigTest, OperatorLess);
|
| +
|
| + // Each StoragePartition is uniquely identified by which partition domain
|
| + // it belongs to (such as an app or the browser itself), the user supplied
|
| + // partition name and the bit indicating whether it should be persisted on
|
| + // disk or not. This structure contains those elements and is used as
|
| + // uniqueness key to lookup StoragePartition objects in the global map.
|
| + //
|
| + // TODO(nasko): It is equivalent, though not identical to the same structure
|
| + // that lives in chrome profiles. The difference is that this one has
|
| + // partition_domain and partition_name separate, while the latter one has
|
| + // the path produced by combining the two pieces together.
|
| + // The fix for http://crbug.com/159193 will remove the chrome version.
|
| + struct StoragePartitionConfig {
|
| + const std::string partition_domain;
|
| + const std::string partition_name;
|
| + const bool in_memory;
|
| +
|
| + StoragePartitionConfig(const std::string& domain,
|
| + const std::string& partition,
|
| + const bool& in_memory_only)
|
| + : partition_domain(domain),
|
| + partition_name(partition),
|
| + in_memory(in_memory_only) {}
|
| + };
|
| +
|
| + // Functor for operator <.
|
| + struct StoragePartitionConfigLess {
|
| + bool operator()(const StoragePartitionConfig& lhs,
|
| + const StoragePartitionConfig& rhs) const {
|
| + if (lhs.partition_domain != rhs.partition_domain)
|
| + return lhs.partition_domain < rhs.partition_domain;
|
| + else if (lhs.partition_name != rhs.partition_name)
|
| + return lhs.partition_name < rhs.partition_name;
|
| + else if (lhs.in_memory != rhs.in_memory)
|
| + return lhs.in_memory < rhs.in_memory;
|
| + else
|
| + return false;
|
| + }
|
| + };
|
| +
|
| + typedef std::map<StoragePartitionConfig,
|
| StoragePartitionImpl*,
|
| - StoragePartitionImpl::StoragePartitionConfigLess>
|
| + StoragePartitionConfigLess>
|
| PartitionMap;
|
|
|
| + // Returns the relative path from the profile's base directory, to the
|
| + // directory that holds all the state for storage contexts in the given
|
| + // |partition_domain| and |partition_name|.
|
| + static FilePath GetStoragePartitionPath(const std::string& partition_domain,
|
| + const std::string& partition_name);
|
| +
|
| // This must always be called *after* |partition| has been added to the
|
| // partitions_.
|
| //
|
|
|