Kaydet (Commit) 4ae5f138 authored tarafından Hirokazu Yamamoto's avatar Hirokazu Yamamoto

Issue #6317: Now winsound.PlaySound only accepts unicode with MvL's approval.

üst be3da38e
...@@ -251,6 +251,8 @@ Library ...@@ -251,6 +251,8 @@ Library
Extension Modules Extension Modules
----------------- -----------------
- Issue #6317: Now winsound.PlaySound only accepts unicode.
- Issue #6317: Now winsound.PlaySound can accept non ascii filename. - Issue #6317: Now winsound.PlaySound can accept non ascii filename.
- Issue #9377: Use Unicode API for gethostname on Windows. - Issue #9377: Use Unicode API for gethostname on Windows.
......
...@@ -73,8 +73,6 @@ static PyObject * ...@@ -73,8 +73,6 @@ static PyObject *
sound_playsound(PyObject *s, PyObject *args) sound_playsound(PyObject *s, PyObject *args)
{ {
Py_UNICODE *wsound; Py_UNICODE *wsound;
PyObject *osound;
const char *sound;
int flags; int flags;
int ok; int ok;
...@@ -95,31 +93,7 @@ sound_playsound(PyObject *s, PyObject *args) ...@@ -95,31 +93,7 @@ sound_playsound(PyObject *s, PyObject *args)
Py_INCREF(Py_None); Py_INCREF(Py_None);
return Py_None; return Py_None;
} }
/* Drop the argument parsing error as narrow strings return NULL;
are also valid. */
PyErr_Clear();
if (!PyArg_ParseTuple(args, "O&i:PlaySound",
PyUnicode_FSConverter, &osound, &flags))
return NULL;
if (flags & SND_ASYNC && flags & SND_MEMORY) {
/* Sidestep reference counting headache; unfortunately this also
prevent SND_LOOP from memory. */
PyErr_SetString(PyExc_RuntimeError, "Cannot play asynchronously from memory");
Py_DECREF(osound);
return NULL;
}
sound = PyBytes_AsString(osound);
Py_BEGIN_ALLOW_THREADS
ok = PlaySoundA(sound, NULL, flags);
Py_END_ALLOW_THREADS
if (!ok) {
PyErr_SetString(PyExc_RuntimeError, "Failed to play sound");
Py_DECREF(osound);
return NULL;
}
Py_DECREF(osound);
Py_INCREF(Py_None);
return Py_None;
} }
static PyObject * static PyObject *
......
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