| Index: third_party/google-endpoints/libpasteurize/fixes/feature_base.py
|
| diff --git a/third_party/google-endpoints/libpasteurize/fixes/feature_base.py b/third_party/google-endpoints/libpasteurize/fixes/feature_base.py
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..8a264964c92bf356512bcb8c704f469b86e0bad8
|
| --- /dev/null
|
| +++ b/third_party/google-endpoints/libpasteurize/fixes/feature_base.py
|
| @@ -0,0 +1,57 @@
|
| +u"""
|
| +Base classes for features that are backwards-incompatible.
|
| +
|
| +Usage:
|
| +features = Features()
|
| +features.add(Feature("py3k_feature", "power< 'py3k' any* >", "2.7"))
|
| +PATTERN = features.PATTERN
|
| +"""
|
| +
|
| +pattern_unformatted = u"%s=%s" # name=pattern, for dict lookups
|
| +message_unformatted = u"""
|
| +%s is only supported in Python %s and above."""
|
| +
|
| +class Feature(object):
|
| + u"""
|
| + A feature has a name, a pattern, and a minimum version of Python 2.x
|
| + required to use the feature (or 3.x if there is no backwards-compatible
|
| + version of 2.x)
|
| + """
|
| + def __init__(self, name, PATTERN, version):
|
| + self.name = name
|
| + self._pattern = PATTERN
|
| + self.version = version
|
| +
|
| + def message_text(self):
|
| + u"""
|
| + Format the above text with the name and minimum version required.
|
| + """
|
| + return message_unformatted % (self.name, self.version)
|
| +
|
| +class Features(set):
|
| + u"""
|
| + A set of features that generates a pattern for the features it contains.
|
| + This set will act like a mapping in that we map names to patterns.
|
| + """
|
| + mapping = {}
|
| +
|
| + def update_mapping(self):
|
| + u"""
|
| + Called every time we care about the mapping of names to features.
|
| + """
|
| + self.mapping = dict([(f.name, f) for f in iter(self)])
|
| +
|
| + @property
|
| + def PATTERN(self):
|
| + u"""
|
| + Uses the mapping of names to features to return a PATTERN suitable
|
| + for using the lib2to3 patcomp.
|
| + """
|
| + self.update_mapping()
|
| + return u" |\n".join([pattern_unformatted % (f.name, f._pattern) for f in iter(self)])
|
| +
|
| + def __getitem__(self, key):
|
| + u"""
|
| + Implement a simple mapping to get patterns from names.
|
| + """
|
| + return self.mapping[key]
|
|
|