aboutsummaryrefslogtreecommitdiff
path: root/debian/patches/04_make-requests.packages.urllib3-same-as-urllib3.patch
blob: 4e6f053c27b51a391b68467cf9fb1db64fe7aeca (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
Description: Make Python import system know that requests.packages.urllib3 and
urllib3 are the same thing.
Author: Jakub Wilk <jwilk@debian.org>
Forwarded: not-needed
Bug-Debian: https://bugs.debian.org/769047
Bug-Debian: https://bugs.debian.org/769496
Last-Update: 2014-11-14

--- a/requests/__init__.py
+++ b/requests/__init__.py
@@ -48,6 +48,28 @@
 __license__ = 'Apache 2.0'
 __copyright__ = 'Copyright 2014 Kenneth Reitz'
 
+# On Debian make Python import system know that requests.packages.urllib3
+# and urllib3 are the same thing.
+import pkgutil
+import sys
+import urllib3
+
+def _attach_namespace(package, where):
+    # Attach package top namespace
+    sys.modules[where + '.' + package.__name__] = package
+    for loader, name, ispkg in pkgutil.walk_packages(package.__path__,
+                                                     package.__name__ + '.'):
+        try:
+            module = __import__(name)
+        except ImportError:
+            continue
+        sys.modules[where + '.' + name] = module
+
+_attach_namespace(urllib3, 'requests.packages')
+del _attach_namespace
+# Python 3 needs this imported explicitly.
+import requests.packages
+
 # Attempt to enable urllib3's SNI support, if possible
 try:
     from urllib3.contrib import pyopenssl
--- a/requests/packages/__init__.py
+++ b/requests/packages/__init__.py
@@ -1,3 +1,3 @@
 from __future__ import absolute_import
 
-from . import urllib3
+import urllib3