Chromium Code Reviews| Index: content/browser/storage_partition_impl.h |
| diff --git a/content/browser/storage_partition_impl.h b/content/browser/storage_partition_impl.h |
| index d3d6dba1593d368802e53d6a84cf76acb440e7ca..b45206787a3f05da62fe9dd24425eff7e0cac95d 100644 |
| --- a/content/browser/storage_partition_impl.h |
| +++ b/content/browser/storage_partition_impl.h |
| @@ -7,6 +7,7 @@ |
| #include "base/compiler_specific.h" |
| #include "base/file_path.h" |
| +#include "base/gtest_prod_util.h" |
| #include "base/memory/ref_counted.h" |
| #include "content/browser/appcache/chrome_appcache_service.h" |
| #include "content/browser/dom_storage/dom_storage_context_impl.h" |
| @@ -19,12 +20,6 @@ class StoragePartitionImpl : public StoragePartition { |
| public: |
| virtual ~StoragePartitionImpl(); |
| - // TODO(ajwong): Break the direct dependency on |context|. We only |
| - // need 3 pieces of info from it. |
| - static StoragePartitionImpl* Create(BrowserContext* context, |
| - const std::string& partition_id, |
| - const FilePath& profile_path); |
| - |
| // StoragePartition interface. |
| virtual FilePath GetPath() OVERRIDE; |
| virtual net::URLRequestContextGetter* GetURLRequestContext() OVERRIDE; |
| @@ -37,8 +32,61 @@ class StoragePartitionImpl : public StoragePartition { |
| virtual IndexedDBContextImpl* GetIndexedDBContext() OVERRIDE; |
| private: |
| + FRIEND_TEST_ALL_PREFIXES(StoragePartitionConfigTest, OperatorLess); |
| friend class StoragePartitionImplMap; |
| + // 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; |
| + } |
| + }; |
| + |
| + // TODO(ajwong): Break the direct dependency on |context|. We only |
| + // need 3 pieces of info from it. |
| + static StoragePartitionImpl* Create( |
| + BrowserContext* context, |
| + const StoragePartitionConfig& partition_id, |
| + const FilePath& profile_path); |
| + |
| + // Returns the relative path from the profile's base directory, to the |
| + // directory that holds all the state for storage contexts in |
| + // |partition_config|. |
|
awong
2012/11/07 18:14:30
Add comment explaining the expected behavior for e
nasko
2012/11/07 18:48:05
Done.
|
| + static FilePath GetStoragePartitionPath( |
| + const StoragePartitionConfig& partition_config); |
| + |
| StoragePartitionImpl( |
| const FilePath& partition_path, |
| quota::QuotaManager* quota_manager, |