Chromium Code Reviews| Index: chrome/common/extensions/docs/server2/permissions_data_source.py |
| diff --git a/chrome/common/extensions/docs/server2/permissions_data_source.py b/chrome/common/extensions/docs/server2/permissions_data_source.py |
| index 7662fa77ab9d91a280d622ebe0f98585ea9259ba..599ad4b5ee9fe6d3ed0b94eda163f1d2a2308ba1 100644 |
| --- a/chrome/common/extensions/docs/server2/permissions_data_source.py |
| +++ b/chrome/common/extensions/docs/server2/permissions_data_source.py |
| @@ -41,18 +41,9 @@ class PermissionsDataSource(object): |
| '''Load and format permissions features to be used by templates. Requries a |
| template data source be set before use. |
| ''' |
| - def __init__(self, |
| - compiled_fs_factory, |
| - file_system, |
| - api_features_path, |
| - permissions_features_path, |
| - permissions_json_path): |
| - self._api_features_path = api_features_path |
| - self._permissions_features_path = permissions_features_path |
| - self._permissions_json_path = permissions_json_path |
| - self._file_system = file_system |
| - self._cache = compiled_fs_factory.Create( |
| - self._CreatePermissionsDataSource, PermissionsDataSource) |
| + def __init__(self, features_bundle): |
| + self._features_bundle = features_bundle |
| + self._cache = None |
| def SetTemplateDataSource(self, template_data_source_factory): |
| '''Initialize a template data source to be used to render partial templates |
| @@ -61,21 +52,13 @@ class PermissionsDataSource(object): |
| self._template_data_source = template_data_source_factory.Create( |
| None, {}) |
| - def _CreatePermissionsDataSource(self, _, content): |
| - '''Combine the contents of |_permissions_json_path| and |
| - |_permissions_features_path|. Filter into lists, one for extensions and |
| - one for apps. |
| - ''' |
| - api_features = Parse(self._file_system.ReadSingle(self._api_features_path)) |
| + def _CreateCache(self): |
| + api_features = self._features_bundle.GetAPIFeatures() |
| + permission_features = self._features_bundle.GetPermissionFeatures() |
| def filter_for_platform(permissions, platform): |
| return _ListifyPermissions(features.Filtered(permissions, platform)) |
| - permissions_json = Parse(self._file_system.ReadSingle( |
| - self._permissions_json_path)) |
| - permission_features = features.MergedWith( |
| - features.Parse(Parse(content)), permissions_json) |
| - |
| _AddDependencyDescriptions(permission_features, api_features) |
| # Turn partial templates into descriptions, ensure anchors are set. |
| for permission in permission_features.values(): |
| @@ -87,10 +70,12 @@ class PermissionsDataSource(object): |
| del permission['partial'] |
| return { |
| - 'declare_apps': filter_for_platform(permission_features, 'app'), |
| + 'declare_apps': filter_for_platform(permission_features, 'apps'), |
| 'declare_extensions': filter_for_platform( |
| - permission_features, 'extension') |
| + permission_features, 'extensions') |
| } |
| def get(self, key): |
| - return self._cache.GetFromFile(self._permissions_features_path)[key] |
| + if self._cache is None: |
| + self._cache = self._CreateCache() |
| + return self._cache.get(key) |
|
not at google - send to devlin
2013/10/01 16:34:34
same comment as in manifest_data_source
Ken Rockot(use gerrit already)
2013/10/01 22:18:16
Done.
|