summaryrefslogtreecommitdiffstats
path: root/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_getcwd.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/fix_getcwd.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/fix_getcwd.py')
-rw-r--r--Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_getcwd.py26
1 files changed, 26 insertions, 0 deletions
diff --git a/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_getcwd.py b/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_getcwd.py
new file mode 100644
index 0000000..9b7f002
--- /dev/null
+++ b/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_getcwd.py
@@ -0,0 +1,26 @@
+u"""
+Fixer for os.getcwd() -> os.getcwdu().
+Also warns about "from os import getcwd", suggesting the above form.
+"""
+
+from lib2to3 import fixer_base
+from lib2to3.fixer_util import Name
+
+class FixGetcwd(fixer_base.BaseFix):
+
+ PATTERN = u"""
+ power< 'os' trailer< dot='.' name='getcwd' > any* >
+ |
+ import_from< 'from' 'os' 'import' bad='getcwd' >
+ """
+
+ def transform(self, node, results):
+ if u"name" in results:
+ name = results[u"name"]
+ name.replace(Name(u"getcwdu", prefix=name.prefix))
+ elif u"bad" in results:
+ # Can't convert to getcwdu and then expect to catch every use.
+ self.cannot_convert(node, u"import os, use os.getcwd() instead.")
+ return
+ else:
+ raise ValueError(u"For some reason, the pattern matcher failed.")