summaryrefslogtreecommitdiffstats
path: root/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/feature_base.py
diff options
context:
space:
mode:
authoryum <yum.food.vr@gmail.com>2022-12-17 17:26:16 -0800
committeryum <yum.food.vr@gmail.com>2022-12-17 17:26:16 -0800
commit4d836989720523cd0363927e3e066f56b9dc445c (patch)
treef7a9ff7cb50eda1ff29e91c78067dcc5e0ce6233 /Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/feature_base.py
parentda754e9cf5b192239826aa1619e1ada3c98daa45 (diff)
Check in `future` package
I hit some issues installing Whisper and had to embed this package. I haven't taken the time to deeply understand what's going on. I think that embedded Python follows different rules about resolving module paths than regular system Python. Basically, `future`'s setup.py has a line like `import src`, where `src` is a module inside future (like `future/src/__init__.py`). This doesn't work unless we put that directory on the search path.
Diffstat (limited to 'Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/feature_base.py')
-rw-r--r--Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/feature_base.py57
1 files changed, 57 insertions, 0 deletions
diff --git a/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/feature_base.py b/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/feature_base.py
new file mode 100644
index 0000000..c36d9a9
--- /dev/null
+++ b/Python/Dependencies/future-0.18.2/src/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]