summaryrefslogtreecommitdiffstats
path: root/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_raise.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_raise.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_raise.py')
-rw-r--r--Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_raise.py25
1 files changed, 25 insertions, 0 deletions
diff --git a/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_raise.py b/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_raise.py
new file mode 100644
index 0000000..9c9c192
--- /dev/null
+++ b/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_raise.py
@@ -0,0 +1,25 @@
+u"""Fixer for 'raise E(V).with_traceback(T)' -> 'raise E, V, T'"""
+
+from lib2to3 import fixer_base
+from lib2to3.fixer_util import Comma, Node, Leaf, token, syms
+
+class FixRaise(fixer_base.BaseFix):
+
+ PATTERN = u"""
+ raise_stmt< 'raise' (power< name=any [trailer< '(' val=any* ')' >]
+ [trailer< '.' 'with_traceback' > trailer< '(' trc=any ')' >] > | any) ['from' chain=any] >"""
+
+ def transform(self, node, results):
+ name, val, trc = (results.get(u"name"), results.get(u"val"), results.get(u"trc"))
+ chain = results.get(u"chain")
+ if chain is not None:
+ self.warning(node, u"explicit exception chaining is not supported in Python 2")
+ chain.prev_sibling.remove()
+ chain.remove()
+ if trc is not None:
+ val = val[0] if val else Leaf(token.NAME, u"None")
+ val.prefix = trc.prefix = u" "
+ kids = [Leaf(token.NAME, u"raise"), name.clone(), Comma(),
+ val.clone(), Comma(), trc.clone()]
+ raise_stmt = Node(syms.raise_stmt, kids)
+ node.replace(raise_stmt)