Commit 4775def2 authored by Raymond Hettinger's avatar Raymond Hettinger

merge

parents 13ec112b 187fa8e4
...@@ -115,6 +115,7 @@ library. :: ...@@ -115,6 +115,7 @@ library. ::
'language' : 'Python' } 'language' : 'Python' }
data = urllib.parse.urlencode(values) data = urllib.parse.urlencode(values)
data = data.encode('utf-8') # data should be bytes
req = urllib.request.Request(url, data) req = urllib.request.Request(url, data)
response = urllib.request.urlopen(req) response = urllib.request.urlopen(req)
the_page = response.read() the_page = response.read()
...@@ -180,6 +181,7 @@ Explorer [#]_. :: ...@@ -180,6 +181,7 @@ Explorer [#]_. ::
headers = { 'User-Agent' : user_agent } headers = { 'User-Agent' : user_agent }
data = urllib.parse.urlencode(values) data = urllib.parse.urlencode(values)
data = data.encode('utf-8')
req = urllib.request.Request(url, data, headers) req = urllib.request.Request(url, data, headers)
response = urllib.request.urlopen(req) response = urllib.request.urlopen(req)
the_page = response.read() the_page = response.read()
......
...@@ -138,14 +138,13 @@ The following classes are provided: ...@@ -138,14 +138,13 @@ The following classes are provided:
*url* should be a string containing a valid URL. *url* should be a string containing a valid URL.
*data* may be a string specifying additional data to send to the *data* may be a bytes object specifying additional data to send to the
server, or ``None`` if no such data is needed. Currently HTTP server, or ``None`` if no such data is needed. Currently HTTP requests are
requests are the only ones that use *data*, in order to choose between the only ones that use *data*; the HTTP request will be a POST instead of a
``'GET'`` and ``'POST'`` when *method* is not specified. GET when the *data* parameter is provided. *data* should be a buffer in the
*data* should be a buffer in the standard standard :mimetype:`application/x-www-form-urlencoded` format. The
:mimetype:`application/x-www-form-urlencoded` format. The :func:`urllib.parse.urlencode` function takes a mapping or sequence of
:func:`urllib.parse.urlencode` function takes a mapping or sequence 2-tuples and returns a string in this format.
of 2-tuples and returns a string in this format.
*headers* should be a dictionary, and will be treated as if *headers* should be a dictionary, and will be treated as if
:meth:`add_header` was called with each key and value as arguments. :meth:`add_header` was called with each key and value as arguments.
...@@ -1183,7 +1182,7 @@ some point in the future. ...@@ -1183,7 +1182,7 @@ some point in the future.
If the *url* uses the :file:`http:` scheme identifier, the optional *data* If the *url* uses the :file:`http:` scheme identifier, the optional *data*
argument may be given to specify a ``POST`` request (normally the request argument may be given to specify a ``POST`` request (normally the request
type is ``GET``). The *data* argument must in standard type is ``GET``). The *data* argument must be a bytes object in standard
:mimetype:`application/x-www-form-urlencoded` format; see the :mimetype:`application/x-www-form-urlencoded` format; see the
:func:`urlencode` function below. :func:`urlencode` function below.
......
...@@ -892,6 +892,8 @@ XMLPARSEAPI(int) ...@@ -892,6 +892,8 @@ XMLPARSEAPI(int)
XML_SetHashSalt(XML_Parser parser, XML_SetHashSalt(XML_Parser parser,
unsigned long hash_salt); unsigned long hash_salt);
#define XML_HAS_SET_HASH_SALT /* Python Only: Defined for pyexpat.c. */
/* If XML_Parse or XML_ParseBuffer have returned XML_STATUS_ERROR, then /* If XML_Parse or XML_ParseBuffer have returned XML_STATUS_ERROR, then
XML_GetErrorCode returns information about the error. XML_GetErrorCode returns information about the error.
*/ */
......
...@@ -1156,8 +1156,13 @@ newxmlparseobject(char *encoding, char *namespace_separator, PyObject *intern) ...@@ -1156,8 +1156,13 @@ newxmlparseobject(char *encoding, char *namespace_separator, PyObject *intern)
else { else {
self->itself = XML_ParserCreate(encoding); self->itself = XML_ParserCreate(encoding);
} }
#if ((XML_MAJOR_VERSION >= 2) && (XML_MINOR_VERSION >= 1)) || defined(XML_HAS_SET_HASH_SALT)
/* This feature was added upstream in libexpat 2.1.0. Our expat copy
* has a backport of this feature where we also define XML_HAS_SET_HASH_SALT
* to indicate that we can still use it. */
XML_SetHashSalt(self->itself, XML_SetHashSalt(self->itself,
(unsigned long)_Py_HashSecret.prefix); (unsigned long)_Py_HashSecret.prefix);
#endif
self->intern = intern; self->intern = intern;
Py_XINCREF(self->intern); Py_XINCREF(self->intern);
PyObject_GC_Track(self); PyObject_GC_Track(self);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment