Skip to content

Commit

Permalink
[compat] Add compat_urllib_request_DataHandler
Browse files Browse the repository at this point in the history
  • Loading branch information
Yen Chi Hsuan committed Oct 18, 2015
1 parent 985e4fd commit 0a67a36
Showing 1 changed file with 44 additions and 0 deletions.
44 changes: 44 additions & 0 deletions youtube_dl/compat.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
from __future__ import unicode_literals

import binascii
import collections
import email
import getpass
import io
import optparse
import os
import re
Expand Down Expand Up @@ -38,6 +41,11 @@
except ImportError: # Python 2
import urlparse as compat_urlparse

try:
import urllib.response as compat_urllib_response
except ImportError: # Python 2
import urllib as compat_urllib_response

try:
import http.cookiejar as compat_cookiejar
except ImportError: # Python 2
Expand Down Expand Up @@ -155,6 +163,40 @@ def compat_urllib_parse_unquote_plus(string, encoding='utf-8', errors='replace')
string = string.replace('+', ' ')
return compat_urllib_parse_unquote(string, encoding, errors)

try:
from urllib.request import DataHandler as compat_urllib_request_DataHandler
except ImportError: # Python < 3.4
# Ported from CPython 98774:1733b3bd46db, Lib/urllib/request.py
class compat_urllib_request_DataHandler(compat_urllib_request.BaseHandler):
def data_open(self, req):
# data URLs as specified in RFC 2397.
#
# ignores POSTed data
#
# syntax:
# dataurl := "data:" [ mediatype ] [ ";base64" ] "," data
# mediatype := [ type "/" subtype ] *( ";" parameter )
# data := *urlchar
# parameter := attribute "=" value
url = req.get_full_url()

scheme, data = url.split(":", 1)
mediatype, data = data.split(",", 1)

# even base64 encoded data URLs might be quoted so unquote in any case:
data = compat_urllib_parse_unquote_to_bytes(data)
if mediatype.endswith(";base64"):
data = binascii.a2b_base64(data)
mediatype = mediatype[:-7]

if not mediatype:
mediatype = "text/plain;charset=US-ASCII"

headers = email.message_from_string(
"Content-type: %s\nContent-length: %d\n" % (mediatype, len(data)))

return compat_urllib_response.addinfourl(io.BytesIO(data), headers, url)

try:
compat_basestring = basestring # Python 2
except NameError:
Expand Down Expand Up @@ -489,6 +531,8 @@ def compat_itertools_count(start=0, step=1):
'compat_urllib_parse_unquote_to_bytes',
'compat_urllib_parse_urlparse',
'compat_urllib_request',
'compat_urllib_request_DataHandler',
'compat_urllib_response',
'compat_urlparse',
'compat_urlretrieve',
'compat_xml_parse_error',
Expand Down

0 comments on commit 0a67a36

Please sign in to comment.