| Index: chrome/common/extensions/docs/server2/features_utility.py
|
| diff --git a/chrome/common/extensions/docs/server2/features_utility.py b/chrome/common/extensions/docs/server2/features_utility.py
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..8db281932827afee02b6d40930f8b28ed605f553
|
| --- /dev/null
|
| +++ b/chrome/common/extensions/docs/server2/features_utility.py
|
| @@ -0,0 +1,70 @@
|
| +# Copyright 2013 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.
|
| +
|
| +from copy import deepcopy
|
| +
|
| +def Parse(features_json):
|
| + '''Standardize the raw features file json |features_json| into a more regular
|
| + format. Return a dictionary of features, keyed by name. Each feature is
|
| + guaranteed to have a 'name' attribute and a 'platforms' attribute that is a
|
| + list of platforms the feature is relevant to. Valid platforms are 'app' or
|
| + 'extension'. Other optional keys may be present in each feature.
|
| +
|
| + Features with a 'whitelist' are only relevant to apps or extensions on that
|
| + whitelist and are not included in the retured features dictionary.
|
| + '''
|
| + features = {}
|
| +
|
| + for name, value in features_json.iteritems():
|
| + # Some feature names corrispond to a list; force a list down to a single
|
| + # feature by removing entries that have a 'whitelist'.
|
| + if isinstance(value, list):
|
| + values = [subvalue for subvalue in value if not 'whitelist' in subvalue]
|
| + if values:
|
| + value = values[0]
|
| + else:
|
| + continue
|
| +
|
| + if 'whitelist' in value:
|
| + continue
|
| +
|
| + features[name] = { 'platforms': [] }
|
| +
|
| + platforms = value.pop('extension_types')
|
| + if platforms == 'all' or 'platform_app' in platforms:
|
| + features[name]['platforms'].append('app')
|
| + if platforms == 'all' or 'extension' in platforms:
|
| + features[name]['platforms'].append('extension')
|
| +
|
| + features[name]['name'] = name
|
| + features[name].update(value)
|
| +
|
| + return features
|
| +
|
| +def Filtered(features, platform=None):
|
| + '''Create a new features dictionary from |features| that contains only items
|
| + relevant to |platform|. Items retained are deepcopied. Returns new features
|
| + dictionary.
|
| + '''
|
| + filtered_features = {}
|
| +
|
| + for name, feature in features.iteritems():
|
| + if not platform or platform in feature['platforms']:
|
| + filtered_features[name] = deepcopy(feature)
|
| +
|
| + return filtered_features
|
| +
|
| +def MergedWith(features, other):
|
| + '''Merge |features| with an additional dictionary to create a new features
|
| + dictionary. If a feature is common to both |features| and |other|, then it is
|
| + merged using the standard dictionary update instead of being overwritten.
|
| + Returns the new features dictionary.
|
| + '''
|
| + for key, value in other.iteritems():
|
| + if key in features:
|
| + features[key].update(value)
|
| + else:
|
| + features[key] = value
|
| +
|
| + return features
|
|
|