mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Merge branch 'master' into osx-functional
This commit is contained in:
commit
dda10c8f69
1
.gitignore
vendored
1
.gitignore
vendored
@ -65,5 +65,6 @@ valgrind.out
|
|||||||
|
|
||||||
.DS_Store
|
.DS_Store
|
||||||
apidocs/c/html/
|
apidocs/c/html/
|
||||||
|
*.swp
|
||||||
python2/
|
python2/
|
||||||
python3/
|
python3/
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
./configure CFLAGS='-g3 -O0' CXXFLAGS='-g3 -O0' --enable-python-plugins $@
|
#./configure PYTHON_VERSION=3 CFLAGS='-g3 -O0' CXXFLAGS='-g3 -O0' $@
|
||||||
|
./configure CFLAGS='-g3 -O0' CXXFLAGS='-g3 -O0' $@
|
||||||
|
@ -71,12 +71,7 @@ AC_ARG_ENABLE([icons],
|
|||||||
# python
|
# python
|
||||||
if test "x$enable_plugins" = xno; then
|
if test "x$enable_plugins" = xno; then
|
||||||
AM_CONDITIONAL([BUILD_PYTHON_API], [false])
|
AM_CONDITIONAL([BUILD_PYTHON_API], [false])
|
||||||
#
|
elif test "x$enable_python_plugins" != xno; then
|
||||||
# Python plugins are temporary disabled by default, because Profanity doesn't
|
|
||||||
# build with all python versions. Change `= xyes` to `!= xno` to enable it by
|
|
||||||
# default.
|
|
||||||
#
|
|
||||||
elif test "x$enable_python_plugins" = xyes; then
|
|
||||||
AS_IF([test "x$PLATFORM" = xosx], [
|
AS_IF([test "x$PLATFORM" = xosx], [
|
||||||
AS_IF([test "x$PYTHON_FRAMEWORK" = x], [ PYTHON_FRAMEWORK="/Library/Frameworks/Python.framework" ])
|
AS_IF([test "x$PYTHON_FRAMEWORK" = x], [ PYTHON_FRAMEWORK="/Library/Frameworks/Python.framework" ])
|
||||||
AC_MSG_NOTICE([Symlinking Python.framework to $PYTHON_FRAMEWORK])
|
AC_MSG_NOTICE([Symlinking Python.framework to $PYTHON_FRAMEWORK])
|
||||||
|
@ -711,6 +711,7 @@ cmd_ac_init(void)
|
|||||||
autocomplete_add(plugins_ac, "load");
|
autocomplete_add(plugins_ac, "load");
|
||||||
autocomplete_add(plugins_ac, "unload");
|
autocomplete_add(plugins_ac, "unload");
|
||||||
autocomplete_add(plugins_ac, "reload");
|
autocomplete_add(plugins_ac, "reload");
|
||||||
|
autocomplete_add(plugins_ac, "python_version");
|
||||||
|
|
||||||
filepath_ac = autocomplete_new();
|
filepath_ac = autocomplete_new();
|
||||||
|
|
||||||
|
@ -1982,14 +1982,16 @@ static struct cmd_t command_defs[] =
|
|||||||
"/plugins install <path>",
|
"/plugins install <path>",
|
||||||
"/plugins unload <plugin>",
|
"/plugins unload <plugin>",
|
||||||
"/plugins load <plugin>",
|
"/plugins load <plugin>",
|
||||||
"/plugins reload [<plugin>]")
|
"/plugins reload [<plugin>]",
|
||||||
|
"/plugins python_version")
|
||||||
CMD_DESC(
|
CMD_DESC(
|
||||||
"Manage plugins. Passing no arguments lists currently loaded plugins.")
|
"Manage plugins. Passing no arguments lists currently loaded plugins.")
|
||||||
CMD_ARGS(
|
CMD_ARGS(
|
||||||
{ "install <file>", "Install file to plugins directory, and load or reload the plugin." },
|
{ "install <file>", "Install file to plugins directory, and load or reload the plugin." },
|
||||||
{ "load <plugin>", "Load a plugin that already exists in the plugin directory." },
|
{ "load <plugin>", "Load a plugin that already exists in the plugin directory." },
|
||||||
{ "unload <plugin>", "Unload a loaded plugin." },
|
{ "unload <plugin>", "Unload a loaded plugin." },
|
||||||
{ "reload [<plugin>]", "Reload a plugin, passing no argument will reload all plugins" })
|
{ "reload [<plugin>]", "Reload a plugin, passing no argument will reload all plugins." },
|
||||||
|
{ "python_version", "Show the Python interpreter version." })
|
||||||
CMD_EXAMPLES(
|
CMD_EXAMPLES(
|
||||||
"/plugin install /home/steveharris/Downloads/metal.py",
|
"/plugin install /home/steveharris/Downloads/metal.py",
|
||||||
"/plugin load browser.py",
|
"/plugin load browser.py",
|
||||||
|
@ -84,6 +84,9 @@
|
|||||||
#include "tray.h"
|
#include "tray.h"
|
||||||
#endif
|
#endif
|
||||||
#include "tools/http_upload.h"
|
#include "tools/http_upload.h"
|
||||||
|
#ifdef HAVE_PYTHON
|
||||||
|
#include "plugins/python_plugins.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
static void _update_presence(const resource_presence_t presence,
|
static void _update_presence(const resource_presence_t presence,
|
||||||
const char *const show, gchar **args);
|
const char *const show, gchar **args);
|
||||||
@ -6109,6 +6112,16 @@ cmd_plugins(ProfWin *window, const char *const command, gchar **args)
|
|||||||
}
|
}
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
} else if (g_strcmp0(args[0], "python_version") == 0) {
|
||||||
|
#ifdef HAVE_PYTHON
|
||||||
|
const char *version = python_get_version();
|
||||||
|
cons_show("Python version:");
|
||||||
|
cons_show("%s", version);
|
||||||
|
#else
|
||||||
|
cons_show("This build does not support pytyon plugins.");
|
||||||
|
#endif
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
GList *plugins = plugins_loaded_list();
|
GList *plugins = plugins_loaded_list();
|
||||||
if (plugins == NULL) {
|
if (plugins == NULL) {
|
||||||
|
@ -159,13 +159,15 @@ callbacks_remove(const char *const plugin_name)
|
|||||||
g_hash_table_remove(p_timed_functions, plugin_name);
|
g_hash_table_remove(p_timed_functions, plugin_name);
|
||||||
|
|
||||||
GHashTable *tag_to_win_cb_hash = g_hash_table_lookup(p_window_callbacks, plugin_name);
|
GHashTable *tag_to_win_cb_hash = g_hash_table_lookup(p_window_callbacks, plugin_name);
|
||||||
GList *tags = g_hash_table_get_keys(tag_to_win_cb_hash);
|
if (tag_to_win_cb_hash) {
|
||||||
GList *curr = tags;
|
GList *tags = g_hash_table_get_keys(tag_to_win_cb_hash);
|
||||||
while (curr) {
|
GList *curr = tags;
|
||||||
wins_close_plugin(curr->data);
|
while (curr) {
|
||||||
curr = g_list_next(curr);
|
wins_close_plugin(curr->data);
|
||||||
|
curr = g_list_next(curr);
|
||||||
|
}
|
||||||
|
g_list_free(tags);
|
||||||
}
|
}
|
||||||
g_list_free(tags);
|
|
||||||
|
|
||||||
g_hash_table_remove(p_window_callbacks, plugin_name);
|
g_hash_table_remove(p_window_callbacks, plugin_name);
|
||||||
}
|
}
|
||||||
|
@ -32,9 +32,13 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
#include <Python.h>
|
#include <Python.h>
|
||||||
#include <frameobject.h>
|
#include <frameobject.h>
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
|
|
||||||
#include "plugins/api.h"
|
#include "plugins/api.h"
|
||||||
@ -54,18 +58,21 @@ python_api_cons_alert(PyObject *self, PyObject *args)
|
|||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_cons_show(PyObject *self, PyObject *args)
|
python_api_cons_show(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *message = NULL;
|
PyObject* message = NULL;
|
||||||
if (!PyArg_ParseTuple(args, "s", &message)) {
|
if (!PyArg_ParseTuple(args, "O", &message)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *message_str = python_str_or_unicode_to_string(message);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_cons_show(message);
|
api_cons_show(message_str);
|
||||||
|
free(message_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -74,15 +81,25 @@ python_api_cons_show(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_cons_show_themed(PyObject *self, PyObject *args)
|
python_api_cons_show_themed(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *group = NULL;
|
PyObject *group = NULL;
|
||||||
const char *key = NULL;
|
PyObject *key = NULL;
|
||||||
const char *def = NULL;
|
PyObject *def = NULL;
|
||||||
const char *message = NULL;
|
PyObject *message = NULL;
|
||||||
if (!PyArg_ParseTuple(args, "zzzs", &group, &key, &def, &message)) {
|
if (!PyArg_ParseTuple(args, "OOOO", &group, &key, &def, &message)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *group_str = python_str_or_unicode_to_string(group);
|
||||||
|
char *key_str = python_str_or_unicode_to_string(key);
|
||||||
|
char *def_str = python_str_or_unicode_to_string(def);
|
||||||
|
char *message_str = python_str_or_unicode_to_string(message);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_cons_show_themed(group, key, def, message);
|
api_cons_show_themed(group_str, key_str, def_str, message_str);
|
||||||
|
free(group_str);
|
||||||
|
free(key_str);
|
||||||
|
free(def_str);
|
||||||
|
free(message_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -91,12 +108,16 @@ python_api_cons_show_themed(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_cons_bad_cmd_usage(PyObject *self, PyObject *args)
|
python_api_cons_bad_cmd_usage(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *cmd = NULL;
|
PyObject *cmd = NULL;
|
||||||
if (!PyArg_ParseTuple(args, "s", &cmd)) {
|
if (!PyArg_ParseTuple(args, "O", &cmd)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *cmd_str = python_str_or_unicode_to_string(cmd);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_cons_bad_cmd_usage(cmd);
|
api_cons_bad_cmd_usage(cmd_str);
|
||||||
|
free(cmd_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -105,22 +126,25 @@ python_api_cons_bad_cmd_usage(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_register_command(PyObject *self, PyObject *args)
|
python_api_register_command(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *command_name = NULL;
|
PyObject *command_name = NULL;
|
||||||
int min_args = 0;
|
int min_args = 0;
|
||||||
int max_args = 0;
|
int max_args = 0;
|
||||||
PyObject *synopsis = NULL;
|
PyObject *synopsis = NULL;
|
||||||
const char *description = NULL;
|
PyObject *description = NULL;
|
||||||
PyObject *arguments = NULL;
|
PyObject *arguments = NULL;
|
||||||
PyObject *examples = NULL;
|
PyObject *examples = NULL;
|
||||||
PyObject *p_callback = NULL;
|
PyObject *p_callback = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "siiOsOOO", &command_name, &min_args, &max_args,
|
if (!PyArg_ParseTuple(args, "OiiOOOOO", &command_name, &min_args, &max_args,
|
||||||
&synopsis, &description, &arguments, &examples, &p_callback)) {
|
&synopsis, &description, &arguments, &examples, &p_callback)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *command_name_str = python_str_or_unicode_to_string(command_name);
|
||||||
|
char *description_str = python_str_or_unicode_to_string(description);
|
||||||
|
|
||||||
char *plugin_name = _python_plugin_name();
|
char *plugin_name = _python_plugin_name();
|
||||||
log_debug("Register command %s for %s", command_name, plugin_name);
|
log_debug("Register command %s for %s", command_name_str, plugin_name);
|
||||||
|
|
||||||
if (p_callback && PyCallable_Check(p_callback)) {
|
if (p_callback && PyCallable_Check(p_callback)) {
|
||||||
Py_ssize_t len = PyList_Size(synopsis);
|
Py_ssize_t len = PyList_Size(synopsis);
|
||||||
@ -128,7 +152,7 @@ python_api_register_command(PyObject *self, PyObject *args)
|
|||||||
Py_ssize_t i = 0;
|
Py_ssize_t i = 0;
|
||||||
for (i = 0; i < len; i++) {
|
for (i = 0; i < len; i++) {
|
||||||
PyObject *item = PyList_GetItem(synopsis, i);
|
PyObject *item = PyList_GetItem(synopsis, i);
|
||||||
char *c_item = PyString_AsString(item);
|
char *c_item = python_str_or_unicode_to_string(item);
|
||||||
c_synopsis[i] = c_item;
|
c_synopsis[i] = c_item;
|
||||||
}
|
}
|
||||||
c_synopsis[len] = NULL;
|
c_synopsis[len] = NULL;
|
||||||
@ -143,11 +167,11 @@ python_api_register_command(PyObject *self, PyObject *args)
|
|||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
PyObject *arg = PyList_GetItem(item, 0);
|
PyObject *arg = PyList_GetItem(item, 0);
|
||||||
char *c_arg = PyString_AsString(arg);
|
char *c_arg = python_str_or_unicode_to_string(arg);
|
||||||
PyObject *desc = PyList_GetItem(item, 1);
|
|
||||||
char *c_desc = PyString_AsString(desc);
|
|
||||||
|
|
||||||
c_arguments[i][0] = c_arg;
|
c_arguments[i][0] = c_arg;
|
||||||
|
|
||||||
|
PyObject *desc = PyList_GetItem(item, 1);
|
||||||
|
char *c_desc = python_str_or_unicode_to_string(desc);
|
||||||
c_arguments[i][1] = c_desc;
|
c_arguments[i][1] = c_desc;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -159,14 +183,16 @@ python_api_register_command(PyObject *self, PyObject *args)
|
|||||||
i = 0;
|
i = 0;
|
||||||
for (i = 0; i < len; i++) {
|
for (i = 0; i < len; i++) {
|
||||||
PyObject *item = PyList_GetItem(examples, i);
|
PyObject *item = PyList_GetItem(examples, i);
|
||||||
char *c_item = PyString_AsString(item);
|
char *c_item = python_str_or_unicode_to_string(item);
|
||||||
c_examples[i] = c_item;
|
c_examples[i] = c_item;
|
||||||
}
|
}
|
||||||
c_examples[len] = NULL;
|
c_examples[len] = NULL;
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_register_command(plugin_name, command_name, min_args, max_args, c_synopsis,
|
api_register_command(plugin_name, command_name_str, min_args, max_args, c_synopsis,
|
||||||
description, c_arguments, c_examples, p_callback, python_command_callback, NULL);
|
description_str, c_arguments, c_examples, p_callback, python_command_callback, NULL);
|
||||||
|
free(command_name_str);
|
||||||
|
free(description_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,15 +228,17 @@ python_api_register_timed(PyObject *self, PyObject *args)
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_completer_add(PyObject *self, PyObject *args)
|
python_api_completer_add(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *key = NULL;
|
PyObject *key = NULL;
|
||||||
PyObject *items = NULL;
|
PyObject *items = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "sO", &key, &items)) {
|
if (!PyArg_ParseTuple(args, "OO", &key, &items)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *key_str = python_str_or_unicode_to_string(key);
|
||||||
|
|
||||||
char *plugin_name = _python_plugin_name();
|
char *plugin_name = _python_plugin_name();
|
||||||
log_debug("Autocomplete add %s for %s", key, plugin_name);
|
log_debug("Autocomplete add %s for %s", key_str, plugin_name);
|
||||||
|
|
||||||
Py_ssize_t len = PyList_Size(items);
|
Py_ssize_t len = PyList_Size(items);
|
||||||
char *c_items[len];
|
char *c_items[len];
|
||||||
@ -218,13 +246,14 @@ python_api_completer_add(PyObject *self, PyObject *args)
|
|||||||
Py_ssize_t i = 0;
|
Py_ssize_t i = 0;
|
||||||
for (i = 0; i < len; i++) {
|
for (i = 0; i < len; i++) {
|
||||||
PyObject *item = PyList_GetItem(items, i);
|
PyObject *item = PyList_GetItem(items, i);
|
||||||
char *c_item = PyString_AsString(item);
|
char *c_item = python_str_or_unicode_to_string(item);
|
||||||
c_items[i] = c_item;
|
c_items[i] = c_item;
|
||||||
}
|
}
|
||||||
c_items[len] = NULL;
|
c_items[len] = NULL;
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_completer_add(plugin_name, key, c_items);
|
api_completer_add(plugin_name, key_str, c_items);
|
||||||
|
free(key_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
free(plugin_name);
|
free(plugin_name);
|
||||||
@ -235,15 +264,17 @@ python_api_completer_add(PyObject *self, PyObject *args)
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_completer_remove(PyObject *self, PyObject *args)
|
python_api_completer_remove(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *key = NULL;
|
PyObject *key = NULL;
|
||||||
PyObject *items = NULL;
|
PyObject *items = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "sO", &key, &items)) {
|
if (!PyArg_ParseTuple(args, "OO", &key, &items)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *key_str = python_str_or_unicode_to_string(key);
|
||||||
|
|
||||||
char *plugin_name = _python_plugin_name();
|
char *plugin_name = _python_plugin_name();
|
||||||
log_debug("Autocomplete remove %s for %s", key, plugin_name);
|
log_debug("Autocomplete remove %s for %s", key_str, plugin_name);
|
||||||
|
|
||||||
Py_ssize_t len = PyList_Size(items);
|
Py_ssize_t len = PyList_Size(items);
|
||||||
char *c_items[len];
|
char *c_items[len];
|
||||||
@ -251,13 +282,14 @@ python_api_completer_remove(PyObject *self, PyObject *args)
|
|||||||
Py_ssize_t i = 0;
|
Py_ssize_t i = 0;
|
||||||
for (i = 0; i < len; i++) {
|
for (i = 0; i < len; i++) {
|
||||||
PyObject *item = PyList_GetItem(items, i);
|
PyObject *item = PyList_GetItem(items, i);
|
||||||
char *c_item = PyString_AsString(item);
|
char *c_item = python_str_or_unicode_to_string(item);
|
||||||
c_items[i] = c_item;
|
c_items[i] = c_item;
|
||||||
}
|
}
|
||||||
c_items[len] = NULL;
|
c_items[len] = NULL;
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_completer_remove(plugin_name, key, c_items);
|
api_completer_remove(plugin_name, key_str, c_items);
|
||||||
|
free(key_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
free(plugin_name);
|
free(plugin_name);
|
||||||
@ -268,17 +300,20 @@ python_api_completer_remove(PyObject *self, PyObject *args)
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_completer_clear(PyObject *self, PyObject *args)
|
python_api_completer_clear(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *key = NULL;
|
PyObject *key = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "s", &key)) {
|
if (!PyArg_ParseTuple(args, "O", &key)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *key_str = python_str_or_unicode_to_string(key);
|
||||||
|
|
||||||
char *plugin_name = _python_plugin_name();
|
char *plugin_name = _python_plugin_name();
|
||||||
log_debug("Autocomplete clear %s for %s", key, plugin_name);
|
log_debug("Autocomplete clear %s for %s", key_str, plugin_name);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_completer_clear(plugin_name, key);
|
api_completer_clear(plugin_name, key_str);
|
||||||
|
free(key_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
free(plugin_name);
|
free(plugin_name);
|
||||||
@ -289,16 +324,21 @@ python_api_completer_clear(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_notify(PyObject *self, PyObject *args)
|
python_api_notify(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *message = NULL;
|
PyObject *message = NULL;
|
||||||
const char *category = NULL;
|
PyObject *category = NULL;
|
||||||
int timeout_ms = 5000;
|
int timeout_ms = 5000;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "sis", &message, &timeout_ms, &category)) {
|
if (!PyArg_ParseTuple(args, "OiO", &message, &timeout_ms, &category)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *message_str = python_str_or_unicode_to_string(message);
|
||||||
|
char *category_str = python_str_or_unicode_to_string(category);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_notify(message, category, timeout_ms);
|
api_notify(message_str, category_str, timeout_ms);
|
||||||
|
free(message_str);
|
||||||
|
free(category_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -307,13 +347,16 @@ python_api_notify(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_send_line(PyObject *self, PyObject *args)
|
python_api_send_line(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *line = NULL;
|
PyObject *line = NULL;
|
||||||
if (!PyArg_ParseTuple(args, "s", &line)) {
|
if (!PyArg_ParseTuple(args, "O", &line)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *line_str = python_str_or_unicode_to_string(line);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_send_line(line);
|
api_send_line(line_str);
|
||||||
|
free(line_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -393,12 +436,16 @@ python_api_current_win_is_console(PyObject *self, PyObject *args)
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_log_debug(PyObject *self, PyObject *args)
|
python_api_log_debug(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *message = NULL;
|
PyObject *message = NULL;
|
||||||
if (!PyArg_ParseTuple(args, "s", &message)) {
|
if (!PyArg_ParseTuple(args, "O", &message)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *message_str = python_str_or_unicode_to_string(message);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_log_debug(message);
|
api_log_debug(message_str);
|
||||||
|
free(message_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -407,13 +454,16 @@ python_api_log_debug(PyObject *self, PyObject *args)
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_log_info(PyObject *self, PyObject *args)
|
python_api_log_info(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *message = NULL;
|
PyObject *message = NULL;
|
||||||
if (!PyArg_ParseTuple(args, "s", &message)) {
|
if (!PyArg_ParseTuple(args, "O", &message)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *message_str = python_str_or_unicode_to_string(message);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_log_info(message);
|
api_log_info(message_str);
|
||||||
|
free(message_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -422,26 +472,34 @@ python_api_log_info(PyObject *self, PyObject *args)
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_log_warning(PyObject *self, PyObject *args)
|
python_api_log_warning(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *message = NULL;
|
PyObject *message = NULL;
|
||||||
if (!PyArg_ParseTuple(args, "s", &message)) {
|
if (!PyArg_ParseTuple(args, "O", &message)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *message_str = python_str_or_unicode_to_string(message);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_log_warning(message);
|
api_log_warning(message_str);
|
||||||
|
free(message_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_log_error(PyObject *self, PyObject *args)
|
python_api_log_error(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *message = NULL;
|
PyObject *message = NULL;
|
||||||
if (!PyArg_ParseTuple(args, "s", &message)) {
|
if (!PyArg_ParseTuple(args, "O", &message)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *message_str = python_str_or_unicode_to_string(message);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_log_error(message);
|
api_log_error(message_str);
|
||||||
|
free(message_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -450,13 +508,16 @@ python_api_log_error(PyObject *self, PyObject *args)
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_win_exists(PyObject *self, PyObject *args)
|
python_api_win_exists(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *tag = NULL;
|
PyObject *tag = NULL;
|
||||||
if (!PyArg_ParseTuple(args, "s", &tag)) {
|
if (!PyArg_ParseTuple(args, "O", &tag)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *tag_str = python_str_or_unicode_to_string(tag);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
gboolean exists = api_win_exists(tag);
|
gboolean exists = api_win_exists(tag_str);
|
||||||
|
free(tag_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
if (exists) {
|
if (exists) {
|
||||||
@ -469,19 +530,22 @@ python_api_win_exists(PyObject *self, PyObject *args)
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_win_create(PyObject *self, PyObject *args)
|
python_api_win_create(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *tag = NULL;
|
PyObject *tag = NULL;
|
||||||
PyObject *p_callback = NULL;
|
PyObject *p_callback = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "sO", &tag, &p_callback)) {
|
if (!PyArg_ParseTuple(args, "OO", &tag, &p_callback)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *tag_str = python_str_or_unicode_to_string(tag);
|
||||||
|
|
||||||
char *plugin_name = _python_plugin_name();
|
char *plugin_name = _python_plugin_name();
|
||||||
log_debug("Win create %s for %s", tag, plugin_name);
|
log_debug("Win create %s for %s", tag_str, plugin_name);
|
||||||
|
|
||||||
if (p_callback && PyCallable_Check(p_callback)) {
|
if (p_callback && PyCallable_Check(p_callback)) {
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_win_create(plugin_name, tag, p_callback, python_window_callback, NULL);
|
api_win_create(plugin_name, tag_str, p_callback, python_window_callback, NULL);
|
||||||
|
free(tag_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -493,14 +557,17 @@ python_api_win_create(PyObject *self, PyObject *args)
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_win_focus(PyObject *self, PyObject *args)
|
python_api_win_focus(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *tag = NULL;
|
PyObject *tag = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "s", &tag)) {
|
if (!PyArg_ParseTuple(args, "O", &tag)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *tag_str = python_str_or_unicode_to_string(tag);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_win_focus(tag);
|
api_win_focus(tag_str);
|
||||||
|
free(tag_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -509,15 +576,20 @@ python_api_win_focus(PyObject *self, PyObject *args)
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_win_show(PyObject *self, PyObject *args)
|
python_api_win_show(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *tag = NULL;
|
PyObject *tag = NULL;
|
||||||
char *line = NULL;
|
PyObject *line = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "ss", &tag, &line)) {
|
if (!PyArg_ParseTuple(args, "OO", &tag, &line)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *tag_str = python_str_or_unicode_to_string(tag);
|
||||||
|
char *line_str = python_str_or_unicode_to_string(line);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_win_show(tag, line);
|
api_win_show(tag_str, line_str);
|
||||||
|
free(tag_str);
|
||||||
|
free(line_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -526,18 +598,30 @@ python_api_win_show(PyObject *self, PyObject *args)
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
python_api_win_show_themed(PyObject *self, PyObject *args)
|
python_api_win_show_themed(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *tag = NULL;
|
PyObject *tag = NULL;
|
||||||
char *group = NULL;
|
PyObject *group = NULL;
|
||||||
char *key = NULL;
|
PyObject *key = NULL;
|
||||||
char *def = NULL;
|
PyObject *def = NULL;
|
||||||
char *line = NULL;
|
PyObject *line = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "szzzs", &tag, &group, &key, &def, &line)) {
|
if (!PyArg_ParseTuple(args, "OOOOO", &tag, &group, &key, &def, &line)) {
|
||||||
|
python_check_error();
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *tag_str = python_str_or_unicode_to_string(tag);
|
||||||
|
char *group_str = python_str_or_unicode_to_string(group);
|
||||||
|
char *key_str = python_str_or_unicode_to_string(key);
|
||||||
|
char *def_str = python_str_or_unicode_to_string(def);
|
||||||
|
char *line_str = python_str_or_unicode_to_string(line);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_win_show_themed(tag, group, key, def, line);
|
api_win_show_themed(tag_str, group_str, key_str, def_str, line_str);
|
||||||
|
free(tag_str);
|
||||||
|
free(group_str);
|
||||||
|
free(key_str);
|
||||||
|
free(def_str);
|
||||||
|
free(line_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -546,13 +630,16 @@ python_api_win_show_themed(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_send_stanza(PyObject *self, PyObject *args)
|
python_api_send_stanza(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
const char *stanza = NULL;
|
PyObject *stanza = NULL;
|
||||||
if (!PyArg_ParseTuple(args, "s", &stanza)) {
|
if (!PyArg_ParseTuple(args, "O", &stanza)) {
|
||||||
return Py_BuildValue("O", Py_False);
|
return Py_BuildValue("O", Py_False);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *stanza_str = python_str_or_unicode_to_string(stanza);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
int res = api_send_stanza(stanza);
|
int res = api_send_stanza(stanza_str);
|
||||||
|
free(stanza_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
if (res) {
|
if (res) {
|
||||||
return Py_BuildValue("O", Py_True);
|
return Py_BuildValue("O", Py_True);
|
||||||
@ -564,18 +651,22 @@ python_api_send_stanza(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_settings_get_boolean(PyObject *self, PyObject *args)
|
python_api_settings_get_boolean(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *group = NULL;
|
PyObject *group = NULL;
|
||||||
char *key = NULL;
|
PyObject *key = NULL;
|
||||||
PyObject *defobj = NULL;
|
PyObject *defobj = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "ssO!", &group, &key, &PyBool_Type, &defobj)) {
|
if (!PyArg_ParseTuple(args, "OOO!", &group, &key, &PyBool_Type, &defobj)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *group_str = python_str_or_unicode_to_string(group);
|
||||||
|
char *key_str = python_str_or_unicode_to_string(key);
|
||||||
int def = PyObject_IsTrue(defobj);
|
int def = PyObject_IsTrue(defobj);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
int res = api_settings_get_boolean(group, key, def);
|
int res = api_settings_get_boolean(group_str, key_str, def);
|
||||||
|
free(group_str);
|
||||||
|
free(key_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
if (res) {
|
if (res) {
|
||||||
@ -588,18 +679,22 @@ python_api_settings_get_boolean(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_settings_set_boolean(PyObject *self, PyObject *args)
|
python_api_settings_set_boolean(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *group = NULL;
|
PyObject *group = NULL;
|
||||||
char *key = NULL;
|
PyObject *key = NULL;
|
||||||
PyObject *valobj = NULL;
|
PyObject *valobj = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "ssO!", &group, &key, &PyBool_Type, &valobj)) {
|
if (!PyArg_ParseTuple(args, "OOO!", &group, &key, &PyBool_Type, &valobj)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *group_str = python_str_or_unicode_to_string(group);
|
||||||
|
char *key_str = python_str_or_unicode_to_string(key);
|
||||||
int val = PyObject_IsTrue(valobj);
|
int val = PyObject_IsTrue(valobj);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_settings_set_boolean(group, key, val);
|
api_settings_set_boolean(group_str, key_str, val);
|
||||||
|
free(group_str);
|
||||||
|
free(key_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -608,16 +703,23 @@ python_api_settings_set_boolean(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_settings_get_string(PyObject *self, PyObject *args)
|
python_api_settings_get_string(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *group = NULL;
|
PyObject *group = NULL;
|
||||||
char *key = NULL;
|
PyObject *key = NULL;
|
||||||
char *def = NULL;
|
PyObject *def = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "ssz", &group, &key, &def)) {
|
if (!PyArg_ParseTuple(args, "OOO", &group, &key, &def)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *group_str = python_str_or_unicode_to_string(group);
|
||||||
|
char *key_str = python_str_or_unicode_to_string(key);
|
||||||
|
char *def_str = python_str_or_unicode_to_string(def);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
char *res = api_settings_get_string(group, key, def);
|
char *res = api_settings_get_string(group_str, key_str, def_str);
|
||||||
|
free(group_str);
|
||||||
|
free(key_str);
|
||||||
|
free(def_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
if (res) {
|
if (res) {
|
||||||
@ -630,16 +732,23 @@ python_api_settings_get_string(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_settings_set_string(PyObject *self, PyObject *args)
|
python_api_settings_set_string(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *group = NULL;
|
PyObject *group = NULL;
|
||||||
char *key = NULL;
|
PyObject *key = NULL;
|
||||||
char *val = NULL;
|
PyObject *val = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "sss", &group, &key, &val)) {
|
if (!PyArg_ParseTuple(args, "OOO", &group, &key, &val)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *group_str = python_str_or_unicode_to_string(group);
|
||||||
|
char *key_str = python_str_or_unicode_to_string(key);
|
||||||
|
char *val_str = python_str_or_unicode_to_string(val);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_settings_set_string(group, key, val);
|
api_settings_set_string(group_str, key_str, val_str);
|
||||||
|
free(group_str);
|
||||||
|
free(key_str);
|
||||||
|
free(val_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -648,16 +757,21 @@ python_api_settings_set_string(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_settings_get_int(PyObject *self, PyObject *args)
|
python_api_settings_get_int(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *group = NULL;
|
PyObject *group = NULL;
|
||||||
char *key = NULL;
|
PyObject *key = NULL;
|
||||||
int def = 0;
|
int def = 0;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "ssi", &group, &key, &def)) {
|
if (!PyArg_ParseTuple(args, "OOi", &group, &key, &def)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *group_str = python_str_or_unicode_to_string(group);
|
||||||
|
char *key_str = python_str_or_unicode_to_string(key);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
int res = api_settings_get_int(group, key, def);
|
int res = api_settings_get_int(group_str, key_str, def);
|
||||||
|
free(group_str);
|
||||||
|
free(key_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("i", res);
|
return Py_BuildValue("i", res);
|
||||||
@ -666,16 +780,21 @@ python_api_settings_get_int(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_settings_set_int(PyObject *self, PyObject *args)
|
python_api_settings_set_int(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *group = NULL;
|
PyObject *group = NULL;
|
||||||
char *key = NULL;
|
PyObject *key = NULL;
|
||||||
int val = 0;
|
int val = 0;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "ssi", &group, &key, &val)) {
|
if (!PyArg_ParseTuple(args, "OOi", &group, &key, &val)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *group_str = python_str_or_unicode_to_string(group);
|
||||||
|
char *key_str = python_str_or_unicode_to_string(key);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_settings_set_int(group, key, val);
|
api_settings_set_int(group_str, key_str, val);
|
||||||
|
free(group_str);
|
||||||
|
free(key_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -684,16 +803,23 @@ python_api_settings_set_int(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_incoming_message(PyObject *self, PyObject *args)
|
python_api_incoming_message(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *barejid = NULL;
|
PyObject *barejid = NULL;
|
||||||
char *resource = NULL;
|
PyObject *resource = NULL;
|
||||||
char *message = NULL;
|
PyObject *message = NULL;
|
||||||
|
|
||||||
if (!PyArg_ParseTuple(args, "sss", &barejid, &resource, &message)) {
|
if (!PyArg_ParseTuple(args, "OOO", &barejid, &resource, &message)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *barejid_str = python_str_or_unicode_to_string(barejid);
|
||||||
|
char *resource_str = python_str_or_unicode_to_string(resource);
|
||||||
|
char *message_str = python_str_or_unicode_to_string(message);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_incoming_message(barejid, resource, message);
|
api_incoming_message(barejid_str, resource_str, message_str);
|
||||||
|
free(barejid_str);
|
||||||
|
free(resource_str);
|
||||||
|
free(message_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -702,13 +828,16 @@ python_api_incoming_message(PyObject *self, PyObject *args)
|
|||||||
static PyObject*
|
static PyObject*
|
||||||
python_api_disco_add_feature(PyObject *self, PyObject *args)
|
python_api_disco_add_feature(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
char *feature = NULL;
|
PyObject *feature = NULL;
|
||||||
if (!PyArg_ParseTuple(args, "s", &feature)) {
|
if (!PyArg_ParseTuple(args, "O", &feature)) {
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *feature_str = python_str_or_unicode_to_string(feature);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
api_disco_add_feature(feature);
|
api_disco_add_feature(feature_str);
|
||||||
|
free(feature_str);
|
||||||
disable_python_threads();
|
disable_python_threads();
|
||||||
|
|
||||||
return Py_BuildValue("");
|
return Py_BuildValue("");
|
||||||
@ -819,10 +948,45 @@ static PyMethodDef apiMethods[] = {
|
|||||||
{ NULL, NULL, 0, NULL }
|
{ NULL, NULL, 0, NULL }
|
||||||
};
|
};
|
||||||
|
|
||||||
void
|
#if PY_MAJOR_VERSION >= 3
|
||||||
|
static struct PyModuleDef profModule =
|
||||||
|
{
|
||||||
|
PyModuleDef_HEAD_INIT,
|
||||||
|
"prof",
|
||||||
|
"",
|
||||||
|
-1,
|
||||||
|
apiMethods
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
PyMODINIT_FUNC
|
||||||
python_api_init(void)
|
python_api_init(void)
|
||||||
{
|
{
|
||||||
|
#if PY_MAJOR_VERSION >= 3
|
||||||
|
PyObject *result = PyModule_Create(&profModule);
|
||||||
|
if (!result) {
|
||||||
|
log_debug("Failed to initialise prof module");
|
||||||
|
} else {
|
||||||
|
log_debug("Initialised prof module");
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
#else
|
||||||
Py_InitModule("prof", apiMethods);
|
Py_InitModule("prof", apiMethods);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
python_init_prof(void)
|
||||||
|
{
|
||||||
|
#if PY_MAJOR_VERSION >= 3
|
||||||
|
PyImport_AppendInittab("prof", python_api_init);
|
||||||
|
Py_Initialize();
|
||||||
|
PyEval_InitThreads();
|
||||||
|
#else
|
||||||
|
Py_Initialize();
|
||||||
|
PyEval_InitThreads();
|
||||||
|
python_api_init();
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static char*
|
static char*
|
||||||
@ -830,10 +994,42 @@ _python_plugin_name(void)
|
|||||||
{
|
{
|
||||||
PyThreadState *ts = PyThreadState_Get();
|
PyThreadState *ts = PyThreadState_Get();
|
||||||
PyFrameObject *frame = ts->frame;
|
PyFrameObject *frame = ts->frame;
|
||||||
char const* filename = PyString_AsString(frame->f_code->co_filename);
|
char const* filename = python_str_or_unicode_to_string(frame->f_code->co_filename);
|
||||||
gchar **split = g_strsplit(filename, "/", 0);
|
gchar **split = g_strsplit(filename, "/", 0);
|
||||||
char *plugin_name = strdup(split[g_strv_length(split)-1]);
|
char *plugin_name = strdup(split[g_strv_length(split)-1]);
|
||||||
g_strfreev(split);
|
g_strfreev(split);
|
||||||
|
|
||||||
return plugin_name;
|
return plugin_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char*
|
||||||
|
python_str_or_unicode_to_string(void *obj)
|
||||||
|
{
|
||||||
|
if (!obj) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
PyObject *pyobj = (PyObject*)obj;
|
||||||
|
if (pyobj == Py_None) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if PY_MAJOR_VERSION >= 3
|
||||||
|
if (PyUnicode_Check(pyobj)) {
|
||||||
|
PyObject *utf8_str = PyUnicode_AsUTF8String(pyobj);
|
||||||
|
char *result = strdup(PyBytes_AS_STRING(utf8_str));
|
||||||
|
Py_XDECREF(utf8_str);
|
||||||
|
return result;
|
||||||
|
} else {
|
||||||
|
return strdup(PyBytes_AS_STRING(pyobj));
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
if (PyUnicode_Check(pyobj)) {
|
||||||
|
PyObject *utf8_str = PyUnicode_AsUTF8String(pyobj);
|
||||||
|
char *result = strdup(PyString_AsString(utf8_str));
|
||||||
|
Py_XDECREF(utf8_str);
|
||||||
|
return result;
|
||||||
|
} else {
|
||||||
|
return strdup(PyString_AsString(pyobj));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
@ -36,11 +36,13 @@
|
|||||||
#define PYTHON_API_H
|
#define PYTHON_API_H
|
||||||
|
|
||||||
void python_env_init(void);
|
void python_env_init(void);
|
||||||
void python_api_init(void);
|
void python_init_prof(void);
|
||||||
void python_shutdown(void);
|
void python_shutdown(void);
|
||||||
|
|
||||||
void python_command_callback(PluginCommand *command, gchar **args);
|
void python_command_callback(PluginCommand *command, gchar **args);
|
||||||
void python_timed_callback(PluginTimedFunction *timed_function);
|
void python_timed_callback(PluginTimedFunction *timed_function);
|
||||||
void python_window_callback(PluginWindowCallback *window_callback, char *tag, char *line);
|
void python_window_callback(PluginWindowCallback *window_callback, char *tag, char *line);
|
||||||
|
|
||||||
|
char* python_str_or_unicode_to_string(void *obj);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -34,6 +34,8 @@
|
|||||||
|
|
||||||
#include <Python.h>
|
#include <Python.h>
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
#include "config/preferences.h"
|
#include "config/preferences.h"
|
||||||
#include "plugins/api.h"
|
#include "plugins/api.h"
|
||||||
#include "plugins/callbacks.h"
|
#include "plugins/callbacks.h"
|
||||||
@ -63,25 +65,31 @@ _unref_module(PyObject *module)
|
|||||||
Py_XDECREF(module);
|
Py_XDECREF(module);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char*
|
||||||
|
python_get_version(void)
|
||||||
|
{
|
||||||
|
return Py_GetVersion();
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
python_env_init(void)
|
python_env_init(void)
|
||||||
{
|
{
|
||||||
loaded_modules = g_hash_table_new_full(g_str_hash, g_str_equal, free, (GDestroyNotify)_unref_module);
|
loaded_modules = g_hash_table_new_full(g_str_hash, g_str_equal, free, (GDestroyNotify)_unref_module);
|
||||||
|
|
||||||
Py_Initialize();
|
python_init_prof();
|
||||||
PyEval_InitThreads();
|
|
||||||
python_api_init();
|
|
||||||
|
|
||||||
|
gchar *plugins_dir = plugins_get_dir();
|
||||||
GString *path = g_string_new("import sys\n");
|
GString *path = g_string_new("import sys\n");
|
||||||
g_string_append(path, "sys.path.append(\"");
|
g_string_append(path, "sys.path.append(\"");
|
||||||
gchar *plugins_dir = plugins_get_dir();
|
|
||||||
g_string_append(path, plugins_dir);
|
g_string_append(path, plugins_dir);
|
||||||
g_free(plugins_dir);
|
|
||||||
g_string_append(path, "/\")\n");
|
g_string_append(path, "/\")\n");
|
||||||
|
|
||||||
PyRun_SimpleString(path->str);
|
PyRun_SimpleString(path->str);
|
||||||
|
python_check_error();
|
||||||
|
|
||||||
g_string_free(path, TRUE);
|
g_string_free(path, TRUE);
|
||||||
|
g_free(plugins_dir);
|
||||||
|
|
||||||
allow_python_threads();
|
allow_python_threads();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -96,7 +104,9 @@ python_plugin_create(const char *const filename)
|
|||||||
} else {
|
} else {
|
||||||
gchar *module_name = g_strndup(filename, strlen(filename) - 3);
|
gchar *module_name = g_strndup(filename, strlen(filename) - 3);
|
||||||
p_module = PyImport_ImportModule(module_name);
|
p_module = PyImport_ImportModule(module_name);
|
||||||
g_hash_table_insert(loaded_modules, strdup(filename), p_module);
|
if (p_module) {
|
||||||
|
g_hash_table_insert(loaded_modules, strdup(filename), p_module);
|
||||||
|
}
|
||||||
g_free(module_name);
|
g_free(module_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -277,20 +287,10 @@ python_pre_chat_message_display_hook(ProfPlugin *plugin, const char *const jid,
|
|||||||
PyObject *result = PyObject_CallObject(p_function, p_args);
|
PyObject *result = PyObject_CallObject(p_function, p_args);
|
||||||
python_check_error();
|
python_check_error();
|
||||||
Py_XDECREF(p_function);
|
Py_XDECREF(p_function);
|
||||||
if (PyUnicode_Check(result)) {
|
char *result_str = python_str_or_unicode_to_string(result);
|
||||||
char *result_str = strdup(PyString_AsString(PyUnicode_AsUTF8String(result)));
|
allow_python_threads();
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
return result_str;
|
||||||
return result_str;
|
|
||||||
} else if (result != Py_None) {
|
|
||||||
char *result_str = strdup(PyString_AsString(result));
|
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
|
||||||
return result_str;
|
|
||||||
} else {
|
|
||||||
allow_python_threads();
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -334,20 +334,10 @@ python_pre_chat_message_send_hook(ProfPlugin *plugin, const char * const jid, co
|
|||||||
PyObject *result = PyObject_CallObject(p_function, p_args);
|
PyObject *result = PyObject_CallObject(p_function, p_args);
|
||||||
python_check_error();
|
python_check_error();
|
||||||
Py_XDECREF(p_function);
|
Py_XDECREF(p_function);
|
||||||
if (PyUnicode_Check(result)) {
|
char *result_str = python_str_or_unicode_to_string(result);
|
||||||
char *result_str = strdup(PyString_AsString(PyUnicode_AsUTF8String(result)));
|
allow_python_threads();
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
return result_str;
|
||||||
return result_str;
|
|
||||||
} else if (result != Py_None) {
|
|
||||||
char *result_str = strdup(PyString_AsString(result));
|
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
|
||||||
return result_str;
|
|
||||||
} else {
|
|
||||||
allow_python_threads();
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -391,20 +381,10 @@ python_pre_room_message_display_hook(ProfPlugin *plugin, const char * const room
|
|||||||
PyObject *result = PyObject_CallObject(p_function, p_args);
|
PyObject *result = PyObject_CallObject(p_function, p_args);
|
||||||
python_check_error();
|
python_check_error();
|
||||||
Py_XDECREF(p_function);
|
Py_XDECREF(p_function);
|
||||||
if (PyUnicode_Check(result)) {
|
char *result_str = python_str_or_unicode_to_string(result);
|
||||||
char *result_str = strdup(PyString_AsString(PyUnicode_AsUTF8String(result)));
|
allow_python_threads();
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
return result_str;
|
||||||
return result_str;
|
|
||||||
} else if (result != Py_None) {
|
|
||||||
char *result_str = strdup(PyString_AsString(result));
|
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
|
||||||
return result_str;
|
|
||||||
} else {
|
|
||||||
allow_python_threads();
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -449,20 +429,10 @@ python_pre_room_message_send_hook(ProfPlugin *plugin, const char *const room, co
|
|||||||
PyObject *result = PyObject_CallObject(p_function, p_args);
|
PyObject *result = PyObject_CallObject(p_function, p_args);
|
||||||
python_check_error();
|
python_check_error();
|
||||||
Py_XDECREF(p_function);
|
Py_XDECREF(p_function);
|
||||||
if (PyUnicode_Check(result)) {
|
char *result_str = python_str_or_unicode_to_string(result);
|
||||||
char *result_str = strdup(PyString_AsString(PyUnicode_AsUTF8String(result)));
|
allow_python_threads();
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
return result_str;
|
||||||
return result_str;
|
|
||||||
} else if (result != Py_None) {
|
|
||||||
char *result_str = strdup(PyString_AsString(result));
|
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
|
||||||
return result_str;
|
|
||||||
} else {
|
|
||||||
allow_python_threads();
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -529,20 +499,10 @@ python_pre_priv_message_display_hook(ProfPlugin *plugin, const char *const room,
|
|||||||
PyObject *result = PyObject_CallObject(p_function, p_args);
|
PyObject *result = PyObject_CallObject(p_function, p_args);
|
||||||
python_check_error();
|
python_check_error();
|
||||||
Py_XDECREF(p_function);
|
Py_XDECREF(p_function);
|
||||||
if (PyUnicode_Check(result)) {
|
char *result_str = python_str_or_unicode_to_string(result);
|
||||||
char *result_str = strdup(PyString_AsString(PyUnicode_AsUTF8String(result)));
|
allow_python_threads();
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
return result_str;
|
||||||
return result_str;
|
|
||||||
} else if (result != Py_None) {
|
|
||||||
char *result_str = strdup(PyString_AsString(result));
|
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
|
||||||
return result_str;
|
|
||||||
} else {
|
|
||||||
allow_python_threads();
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -588,20 +548,10 @@ python_pre_priv_message_send_hook(ProfPlugin *plugin, const char *const room, co
|
|||||||
PyObject *result = PyObject_CallObject(p_function, p_args);
|
PyObject *result = PyObject_CallObject(p_function, p_args);
|
||||||
python_check_error();
|
python_check_error();
|
||||||
Py_XDECREF(p_function);
|
Py_XDECREF(p_function);
|
||||||
if (PyUnicode_Check(result)) {
|
char *result_str = python_str_or_unicode_to_string(result);
|
||||||
char *result_str = strdup(PyString_AsString(PyUnicode_AsUTF8String(result)));
|
allow_python_threads();
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
return result_str;
|
||||||
return result_str;
|
|
||||||
} else if (result != Py_None) {
|
|
||||||
char *result_str = strdup(PyString_AsString(result));
|
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
|
||||||
return result_str;
|
|
||||||
} else {
|
|
||||||
allow_python_threads();
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -646,20 +596,10 @@ python_on_message_stanza_send_hook(ProfPlugin *plugin, const char *const text)
|
|||||||
PyObject *result = PyObject_CallObject(p_function, p_args);
|
PyObject *result = PyObject_CallObject(p_function, p_args);
|
||||||
python_check_error();
|
python_check_error();
|
||||||
Py_XDECREF(p_function);
|
Py_XDECREF(p_function);
|
||||||
if (PyUnicode_Check(result)) {
|
char *result_str = python_str_or_unicode_to_string(result);
|
||||||
char *result_str = strdup(PyString_AsString(PyUnicode_AsUTF8String(result)));
|
allow_python_threads();
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
return result_str;
|
||||||
return result_str;
|
|
||||||
} else if (result != Py_None) {
|
|
||||||
char *result_str = strdup(PyString_AsString(result));
|
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
|
||||||
return result_str;
|
|
||||||
} else {
|
|
||||||
allow_python_threads();
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -711,20 +651,10 @@ python_on_presence_stanza_send_hook(ProfPlugin *plugin, const char *const text)
|
|||||||
PyObject *result = PyObject_CallObject(p_function, p_args);
|
PyObject *result = PyObject_CallObject(p_function, p_args);
|
||||||
python_check_error();
|
python_check_error();
|
||||||
Py_XDECREF(p_function);
|
Py_XDECREF(p_function);
|
||||||
if (PyUnicode_Check(result)) {
|
char *result_str = python_str_or_unicode_to_string(result);
|
||||||
char *result_str = strdup(PyString_AsString(PyUnicode_AsUTF8String(result)));
|
allow_python_threads();
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
return result_str;
|
||||||
return result_str;
|
|
||||||
} else if (result != Py_None) {
|
|
||||||
char *result_str = strdup(PyString_AsString(result));
|
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
|
||||||
return result_str;
|
|
||||||
} else {
|
|
||||||
allow_python_threads();
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -776,20 +706,10 @@ python_on_iq_stanza_send_hook(ProfPlugin *plugin, const char *const text)
|
|||||||
PyObject *result = PyObject_CallObject(p_function, p_args);
|
PyObject *result = PyObject_CallObject(p_function, p_args);
|
||||||
python_check_error();
|
python_check_error();
|
||||||
Py_XDECREF(p_function);
|
Py_XDECREF(p_function);
|
||||||
if (PyUnicode_Check(result)) {
|
char *result_str = python_str_or_unicode_to_string(result);
|
||||||
char *result_str = strdup(PyString_AsString(PyUnicode_AsUTF8String(result)));
|
allow_python_threads();
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
return result_str;
|
||||||
return result_str;
|
|
||||||
} else if (result != Py_None) {
|
|
||||||
char *result_str = strdup(PyString_AsString(result));
|
|
||||||
Py_XDECREF(result);
|
|
||||||
allow_python_threads();
|
|
||||||
return result_str;
|
|
||||||
} else {
|
|
||||||
allow_python_threads();
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -917,6 +837,7 @@ python_check_error(void)
|
|||||||
{
|
{
|
||||||
if (PyErr_Occurred()) {
|
if (PyErr_Occurred()) {
|
||||||
PyErr_Print();
|
PyErr_Print();
|
||||||
|
PyRun_SimpleString("import sys\nsys.stdout.flush()");
|
||||||
PyErr_Clear();
|
PyErr_Clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -43,6 +43,8 @@ void python_check_error(void);
|
|||||||
void allow_python_threads();
|
void allow_python_threads();
|
||||||
void disable_python_threads();
|
void disable_python_threads();
|
||||||
|
|
||||||
|
const char* python_get_version(void);
|
||||||
|
|
||||||
void python_init_hook(ProfPlugin *plugin, const char *const version, const char *const status,
|
void python_init_hook(ProfPlugin *plugin, const char *const version, const char *const status,
|
||||||
const char *const account_name, const char *const fulljid);
|
const char *const account_name, const char *const fulljid);
|
||||||
void python_on_start_hook(ProfPlugin *plugin);
|
void python_on_start_hook(ProfPlugin *plugin);
|
||||||
|
Loading…
Reference in New Issue
Block a user