From 2f5e186341cef8706c6f720f19142108898e8e93 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Ha=C3=AFkel=20Gu=C3=A9mar?= <hguemar@fedoraproject.org>
Date: Fri, 5 Sep 2014 14:36:25 +0200
Subject: [PATCH] Replaced bundled code with using six
Conflicts:
setup.py
(cherry picked from commit 062c5ba16b414770969871b3494f582402476985)
---
requirements.txt | 1 +
retrying.py | 28 ++--------------------------
setup.py | 4 ++++
3 files changed, 7 insertions(+), 26 deletions(-)
diff --git a/requirements.txt b/requirements.txt
index e69de29..ffe2fce 100644
--- a/requirements.txt
+++ b/requirements.txt
@@ -0,0 +1 @@
+six
diff --git a/retrying.py b/retrying.py
index 50fc439..9f0a2a0 100644
--- a/retrying.py
+++ b/retrying.py
@@ -36,35 +36,11 @@
## ----------------------------------------------------------------------------
import random
+import six
import sys
import time
import traceback
-# Python 3 compatibility hacks, pilfered from https://pypi.python.org/pypi/six/1.6.1
-PY3 = sys.version_info[0] == 3
-if PY3:
- def reraise(tp, value, tb=None):
- if value.__traceback__ is not tb:
- raise value.with_traceback(tb)
- raise value
-
-else:
- def exec_(_code_, _globs_=None, _locs_=None):
- """Execute code in a namespace."""
- if _globs_ is None:
- frame = sys._getframe(1)
- _globs_ = frame.f_globals
- if _locs_ is None:
- _locs_ = frame.f_locals
- del frame
- elif _locs_ is None:
- _locs_ = _globs_
- exec("""exec _code_ in _globs_, _locs_""")
-
-
- exec_("""def reraise(tp, value, tb=None):
- raise tp, value, tb
-""")
# sys.maxint / 2, since Python 3.2 doesn't have a sys.maxint...
MAX_WAIT = 1073741823
@@ -282,7 +258,7 @@ class Attempt(object):
if wrap_exception:
raise RetryError(self)
else:
- reraise(self.value[0], self.value[1], self.value[2])
+ six.reraise(self.value[0], self.value[1], self.value[2])
else:
return self.value
diff --git a/setup.py b/setup.py
index 7793b8f..1772179 100644
--- a/setup.py
+++ b/setup.py
@@ -29,6 +29,9 @@ CLASSIFIERS = [
'Topic :: Utilities',
]
+with open('requirements.txt') as file_requirements:
+ requirements = file_requirements.read().splitlines()
+
settings.update(
name='retrying',
version='1.2.3',
@@ -42,6 +45,7 @@ settings.update(
keywords="decorator decorators retry retrying exception exponential backoff",
py_modules= ['retrying'],
test_suite="test_retrying",
+ install_requires=requirements,
)