1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-02-02 15:08:15 -05:00

Plugins: Fix python threading

Release global interpreter lock during api calls
This commit is contained in:
James Booth 2016-03-09 23:36:22 +00:00
parent 85abab6bf9
commit d157e9bf71
2 changed files with 62 additions and 4 deletions

View File

@ -45,8 +45,12 @@
static PyObject* static PyObject*
python_api_cons_alert(PyObject *self, PyObject *args) python_api_cons_alert(PyObject *self, PyObject *args)
{ {
allow_python_threads();
api_cons_alert(); api_cons_alert();
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
static PyObject* static PyObject*
@ -56,7 +60,10 @@ python_api_cons_show(PyObject *self, PyObject *args)
if (!PyArg_ParseTuple(args, "s", &message)) { if (!PyArg_ParseTuple(args, "s", &message)) {
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_cons_show(message); api_cons_show(message);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -70,7 +77,10 @@ python_api_cons_show_themed(PyObject *self, PyObject *args)
if (!PyArg_ParseTuple(args, "zzzs", &group, &key, &def, &message)) { if (!PyArg_ParseTuple(args, "zzzs", &group, &key, &def, &message)) {
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_cons_show_themed(group, key, def, message); api_cons_show_themed(group, key, def, message);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -81,7 +91,10 @@ python_api_cons_bad_cmd_usage(PyObject *self, PyObject *args)
if (!PyArg_ParseTuple(args, "s", &cmd)) { if (!PyArg_ParseTuple(args, "s", &cmd)) {
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_cons_bad_cmd_usage(cmd); api_cons_bad_cmd_usage(cmd);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -144,8 +157,10 @@ python_api_register_command(PyObject *self, PyObject *args)
} }
c_examples[len] = NULL; c_examples[len] = NULL;
allow_python_threads();
api_register_command(command_name, min_args, max_args, c_synopsis, api_register_command(command_name, min_args, max_args, c_synopsis,
description, c_arguments, c_examples, p_callback, python_command_callback); description, c_arguments, c_examples, p_callback, python_command_callback);
disable_python_threads();
} }
return Py_BuildValue(""); return Py_BuildValue("");
@ -162,7 +177,9 @@ python_api_register_timed(PyObject *self, PyObject *args)
} }
if (p_callback && PyCallable_Check(p_callback)) { if (p_callback && PyCallable_Check(p_callback)) {
allow_python_threads();
api_register_timed(p_callback, interval_seconds, python_timed_callback); api_register_timed(p_callback, interval_seconds, python_timed_callback);
disable_python_threads();
} }
return Py_BuildValue(""); return Py_BuildValue("");
@ -189,7 +206,10 @@ python_api_register_ac(PyObject *self, PyObject *args)
} }
c_items[len] = NULL; c_items[len] = NULL;
allow_python_threads();
autocompleters_add(key, c_items); autocompleters_add(key, c_items);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -204,7 +224,9 @@ python_api_notify(PyObject *self, PyObject *args)
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_notify(message, category, timeout_ms); api_notify(message, category, timeout_ms);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -217,7 +239,9 @@ python_api_send_line(PyObject *self, PyObject *args)
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_send_line(line); api_send_line(line);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -225,7 +249,9 @@ python_api_send_line(PyObject *self, PyObject *args)
static PyObject * static PyObject *
python_api_get_current_recipient(PyObject *self, PyObject *args) python_api_get_current_recipient(PyObject *self, PyObject *args)
{ {
allow_python_threads();
char *recipient = api_get_current_recipient(); char *recipient = api_get_current_recipient();
disable_python_threads();
if (recipient) { if (recipient) {
return Py_BuildValue("s", recipient); return Py_BuildValue("s", recipient);
} else { } else {
@ -236,7 +262,9 @@ python_api_get_current_recipient(PyObject *self, PyObject *args)
static PyObject * static PyObject *
python_api_get_current_muc(PyObject *self, PyObject *args) python_api_get_current_muc(PyObject *self, PyObject *args)
{ {
allow_python_threads();
char *room = api_get_current_muc(); char *room = api_get_current_muc();
disable_python_threads();
if (room) { if (room) {
return Py_BuildValue("s", room); return Py_BuildValue("s", room);
} else { } else {
@ -247,7 +275,9 @@ python_api_get_current_muc(PyObject *self, PyObject *args)
static PyObject* static PyObject*
python_api_current_win_is_console(PyObject *self, PyObject *args) python_api_current_win_is_console(PyObject *self, PyObject *args)
{ {
allow_python_threads();
int res = api_current_win_is_console(); int res = api_current_win_is_console();
disable_python_threads();
if (res) { if (res) {
return Py_BuildValue("O", Py_True); return Py_BuildValue("O", Py_True);
} else { } else {
@ -262,7 +292,10 @@ python_api_log_debug(PyObject *self, PyObject *args)
if (!PyArg_ParseTuple(args, "s", &message)) { if (!PyArg_ParseTuple(args, "s", &message)) {
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_log_debug(message); api_log_debug(message);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -273,7 +306,11 @@ python_api_log_info(PyObject *self, PyObject *args)
if (!PyArg_ParseTuple(args, "s", &message)) { if (!PyArg_ParseTuple(args, "s", &message)) {
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_log_info(message); api_log_info(message);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -284,7 +321,10 @@ python_api_log_warning(PyObject *self, PyObject *args)
if (!PyArg_ParseTuple(args, "s", &message)) { if (!PyArg_ParseTuple(args, "s", &message)) {
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_log_warning(message); api_log_warning(message);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -295,7 +335,10 @@ python_api_log_error(PyObject *self, PyObject *args)
if (!PyArg_ParseTuple(args, "s", &message)) { if (!PyArg_ParseTuple(args, "s", &message)) {
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_log_error(message); api_log_error(message);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -307,7 +350,11 @@ python_api_win_exists(PyObject *self, PyObject *args)
return Py_BuildValue(""); return Py_BuildValue("");
} }
if (api_win_exists(tag)) { allow_python_threads();
gboolean exists = api_win_exists(tag);
disable_python_threads();
if (exists) {
return Py_BuildValue("i", 1); return Py_BuildValue("i", 1);
} else { } else {
return Py_BuildValue("i", 0); return Py_BuildValue("i", 0);
@ -325,7 +372,9 @@ python_api_win_create(PyObject *self, PyObject *args)
} }
if (p_callback && PyCallable_Check(p_callback)) { if (p_callback && PyCallable_Check(p_callback)) {
allow_python_threads();
api_win_create(tag, p_callback, NULL, python_window_callback); api_win_create(tag, p_callback, NULL, python_window_callback);
disable_python_threads();
} }
return Py_BuildValue(""); return Py_BuildValue("");
@ -340,7 +389,10 @@ python_api_win_focus(PyObject *self, PyObject *args)
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_win_focus(tag); api_win_focus(tag);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -354,7 +406,10 @@ python_api_win_show(PyObject *self, PyObject *args)
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_win_show(tag, line); api_win_show(tag, line);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }
@ -371,7 +426,10 @@ python_api_win_show_themed(PyObject *self, PyObject *args)
return Py_BuildValue(""); return Py_BuildValue("");
} }
allow_python_threads();
api_win_show_themed(tag, group, key, def, line); api_win_show_themed(tag, group, key, def, line);
disable_python_threads();
return Py_BuildValue(""); return Py_BuildValue("");
} }

View File

@ -42,18 +42,18 @@
#include "plugins/python_plugins.h" #include "plugins/python_plugins.h"
#include "ui/ui.h" #include "ui/ui.h"
//static PyThreadState *thread_state; static PyThreadState *thread_state;
void void
allow_python_threads() allow_python_threads()
{ {
// thread_state = PyEval_SaveThread(); thread_state = PyEval_SaveThread();
} }
void void
disable_python_threads() disable_python_threads()
{ {
// PyEval_RestoreThread(thread_state); PyEval_RestoreThread(thread_state);
} }
void void