summaryrefslogtreecommitdiffstats
path: root/FOSS/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_next.py
diff options
context:
space:
mode:
authoryum <yum.food.vr@gmail.com>2023-01-01 21:05:27 -0800
committeryum <yum.food.vr@gmail.com>2023-01-01 21:44:45 -0800
commite25bdba3a3a53b09be5269d8b065c13b73ab55c3 (patch)
tree1d1dc1d94cde92c2f4f8ce86017395054787515d /FOSS/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_next.py
parent0d408cc812a094a708edbe4baf536e928731cfc3 (diff)
Embed git in package
package.ps1 fetches PortableGit and embeds it in the package. This eliminates all but one runtime dependency (MSVC++ Redistributable). * Move Python into a new FOSS folder.
Diffstat (limited to 'FOSS/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_next.py')
-rw-r--r--FOSS/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_next.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/FOSS/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_next.py b/FOSS/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_next.py
new file mode 100644
index 0000000..9ecb6c0
--- /dev/null
+++ b/FOSS/Python/Dependencies/future-0.18.2/src/libpasteurize/fixes/fix_next.py
@@ -0,0 +1,43 @@
+u"""
+Fixer for:
+it.__next__() -> it.next().
+next(it) -> it.next().
+"""
+
+from lib2to3.pgen2 import token
+from lib2to3.pygram import python_symbols as syms
+from lib2to3 import fixer_base
+from lib2to3.fixer_util import Name, Call, find_binding, Attr
+
+bind_warning = u"Calls to builtin next() possibly shadowed by global binding"
+
+
+class FixNext(fixer_base.BaseFix):
+
+ PATTERN = u"""
+ power< base=any+ trailer< '.' attr='__next__' > any* >
+ |
+ power< head='next' trailer< '(' arg=any ')' > any* >
+ |
+ classdef< 'class' base=any+ ':'
+ suite< any*
+ funcdef< 'def'
+ attr='__next__'
+ parameters< '(' NAME ')' > any+ >
+ any* > >
+ """
+
+ def transform(self, node, results):
+ assert results
+
+ base = results.get(u"base")
+ attr = results.get(u"attr")
+ head = results.get(u"head")
+ arg_ = results.get(u"arg")
+ if arg_:
+ arg = arg_.clone()
+ head.replace(Attr(Name(unicode(arg),prefix=head.prefix),
+ Name(u"next")))
+ arg_.remove()
+ elif base:
+ attr.replace(Name(u"next", prefix=attr.prefix))