mirror of
https://github.com/rkd77/elinks.git
synced 2024-12-04 14:46:47 -05:00
[scripting] python scripting with Python3.
Only utf-8 encoding is supported.
This commit is contained in:
parent
e8addcb561
commit
b3e01b3298
16
configure.ac
16
configure.ac
@ -824,7 +824,7 @@ AC_ARG_WITH(python, [[ --with-python[=DIR] enable Python support]],
|
||||
EL_SAVE_FLAGS
|
||||
cf_result=no
|
||||
|
||||
AC_MSG_CHECKING([for Python])
|
||||
AC_MSG_CHECKING([for Python3])
|
||||
|
||||
if test "$enable_python" = "yes"; then
|
||||
AC_MSG_RESULT(yes);
|
||||
@ -835,13 +835,13 @@ if test "$enable_python" = "yes"; then
|
||||
PYTHON_PATH="$PATH"
|
||||
fi
|
||||
|
||||
AC_PATH_PROG(PYTHON, python, no, $PYTHON_PATH)
|
||||
AC_PATH_PROG(PYTHON3, python3, no, $PYTHON_PATH)
|
||||
|
||||
if test "$PYTHON" != no; then
|
||||
if test "$PYTHON3" != no; then
|
||||
cf_result="yes";
|
||||
|
||||
PYTHON_CFLAGS="`$PYTHON -c 'from distutils import sysconfig; print "-I%s -I%s" % (sysconfig.get_python_inc(), sysconfig.get_python_inc(plat_specific=True))'`"
|
||||
PYTHON_LIBS="`$PYTHON -c 'from distutils import sysconfig; var = sysconfig.get_config_var; print "%s %s %s -L%s -lpython%s" % (var("LINKFORSHARED"), var("LIBS"), var("SYSLIBS"), var("LIBPL"), var("VERSION"))'`"
|
||||
PYTHON_CFLAGS="`$PYTHON3 -c 'from distutils import sysconfig; print("-I%s -I%s" % (sysconfig.get_python_inc(), sysconfig.get_python_inc(plat_specific=True)))'`"
|
||||
PYTHON_LIBS="`$PYTHON3 -c 'from distutils import sysconfig; var = sysconfig.get_config_var; print("%s %s %s -L%s -lpython%s" % (var("LINKFORSHARED"), var("LIBS"), var("SYSLIBS"), var("LIBPL"), var("VERSION")))'`"
|
||||
LIBS="$PYTHON_LIBS $LIBS"
|
||||
CPPFLAGS="$CPPFLAGS $PYTHON_CFLAGS"
|
||||
AC_LINK_IFELSE([AC_LANG_PROGRAM([[#include <Python.h>]], [[Py_Initialize();]])],[cf_result=yes],[cf_result=no])
|
||||
@ -849,7 +849,7 @@ if test "$enable_python" = "yes"; then
|
||||
if test "$cf_result" != "yes"; then
|
||||
EL_RESTORE_FLAGS
|
||||
else
|
||||
EL_CONFIG(CONFIG_SCRIPTING_PYTHON, [Python])
|
||||
EL_CONFIG(CONFIG_SCRIPTING_PYTHON, [Python3])
|
||||
AC_SUBST(PYTHON_LIBS)
|
||||
AC_SUBST(PYTHON_CFLAGS)
|
||||
CPPFLAGS="$CPPFLAGS_X"
|
||||
@ -864,9 +864,9 @@ EOF
|
||||
fi
|
||||
else
|
||||
if test -n "$withval" && test "x$withval" != xno; then
|
||||
AC_MSG_ERROR([Python not found])
|
||||
AC_MSG_ERROR([Python3 not found])
|
||||
else
|
||||
AC_MSG_WARN([Python support disabled])
|
||||
AC_MSG_WARN([Python3 support disabled])
|
||||
fi
|
||||
fi
|
||||
else
|
||||
|
@ -24,6 +24,7 @@ quit_hook() -- Clean up before ELinks exits.
|
||||
"""
|
||||
|
||||
import elinks
|
||||
from importlib import reload
|
||||
|
||||
dumbprefixes = {
|
||||
"7th" : "http://7thguard.net/",
|
||||
@ -96,10 +97,6 @@ def pre_format_html_hook(url, html):
|
||||
elif url.startswith("https://www.mbank.com.pl/ib_navibar_3.asp"):
|
||||
return html.replace('<td valign="top"><img',
|
||||
'<tr><td valign="top"><img')
|
||||
elif url.startswith("http://lp3.polskieradio.pl/"):
|
||||
from lp3 import lp3
|
||||
return lp3(html)
|
||||
|
||||
|
||||
def proxy_for_hook(url):
|
||||
"""Determine what proxy server to use for a given URL.
|
||||
|
@ -1,11 +0,0 @@
|
||||
import re
|
||||
|
||||
PATTERN = re.compile('<a href="javascript:void\(null\);" onclick="\s*play\(this,\'(http://lp3.polskieradio.pl/_files/mp3/.*mp3)\'\);\s*">')
|
||||
|
||||
def zamien(m):
|
||||
|
||||
return '<a href="' + m.group(1) + '">'
|
||||
|
||||
def lp3(html):
|
||||
|
||||
return PATTERN.sub(zamien, html)
|
@ -4,6 +4,7 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#define PY_SSIZE_T_CLEAN
|
||||
#include <Python.h>
|
||||
#include <osdefs.h>
|
||||
|
||||
@ -67,13 +68,13 @@ alert_python_error(void)
|
||||
* of strings into one Python string containing the entire error
|
||||
* message. Then get the contents of the Python string.
|
||||
*/
|
||||
empty_string = PyString_FromString("");
|
||||
empty_string = PyUnicode_FromString("");
|
||||
if (!empty_string) goto end;
|
||||
|
||||
msg_string = PyObject_CallMethod(empty_string, "join", "O", msg_list);
|
||||
if (!msg_string) goto end;
|
||||
|
||||
temp = (unsigned char *) PyString_AsString(msg_string);
|
||||
temp = (unsigned char *) PyUnicode_AsUTF8(msg_string);
|
||||
if (temp) msg = temp;
|
||||
|
||||
end:
|
||||
@ -206,7 +207,7 @@ replace_showwarning(void)
|
||||
|
||||
warnings_module = PyImport_ImportModule("warnings");
|
||||
if (!warnings_module) goto end;
|
||||
module_name = PyString_FromString("warnings");
|
||||
module_name = PyUnicode_FromString("warnings");
|
||||
if (!module_name) goto end;
|
||||
module_dict = PyModule_GetDict(warnings_module);
|
||||
if (!module_dict) goto end;
|
||||
@ -250,48 +251,152 @@ Other public objects:\n\
|
||||
home -- A string containing the pathname of the ~/.elinks directory, or\n\
|
||||
None if ELinks has no configuration directory.\n");
|
||||
|
||||
void
|
||||
init_python(struct module *module)
|
||||
static PyMethodDef python_methods[] = {
|
||||
{"info_box", (PyCFunction)python_info_box,
|
||||
METH_VARARGS | METH_KEYWORDS,
|
||||
python_info_box_doc},
|
||||
|
||||
{"input_box", (PyCFunction)python_input_box,
|
||||
METH_VARARGS | METH_KEYWORDS,
|
||||
python_input_box_doc},
|
||||
|
||||
{"current_document", python_current_document,
|
||||
METH_NOARGS,
|
||||
python_current_document_doc},
|
||||
|
||||
{"current_header", python_current_header,
|
||||
METH_NOARGS,
|
||||
python_current_header_doc},
|
||||
|
||||
{"current_link_url", python_current_link_url,
|
||||
METH_NOARGS,
|
||||
python_current_link_url_doc},
|
||||
|
||||
{"current_title", python_current_title,
|
||||
METH_NOARGS,
|
||||
python_current_title_doc},
|
||||
|
||||
{"current_url", python_current_url,
|
||||
METH_NOARGS,
|
||||
python_current_url_doc},
|
||||
|
||||
{"bind_key", (PyCFunction)python_bind_key,
|
||||
METH_VARARGS | METH_KEYWORDS,
|
||||
python_bind_key_doc},
|
||||
|
||||
{"load", python_load,
|
||||
METH_VARARGS,
|
||||
python_load_doc},
|
||||
|
||||
{"menu", (PyCFunction)python_menu,
|
||||
METH_VARARGS | METH_KEYWORDS,
|
||||
python_menu_doc},
|
||||
|
||||
{"open", (PyCFunction)python_open,
|
||||
METH_VARARGS | METH_KEYWORDS,
|
||||
python_open_doc},
|
||||
|
||||
{NULL, NULL, 0, NULL}
|
||||
};
|
||||
|
||||
static struct PyModuleDef moduledef = {
|
||||
PyModuleDef_HEAD_INIT,
|
||||
"elinks", /* m_name */
|
||||
module_doc, /* m_doc */
|
||||
-1, /* m_size */
|
||||
python_methods, /* m_methods */
|
||||
NULL, /* m_reload */
|
||||
NULL, /* m_traverse */
|
||||
NULL, /* m_clear */
|
||||
NULL, /* m_free */
|
||||
};
|
||||
|
||||
static int
|
||||
add_constant(PyObject *dict, const char *key, int value)
|
||||
{
|
||||
PyObject *constant = PyLong_FromLong(value);
|
||||
int result;
|
||||
|
||||
if (!constant) return -1;
|
||||
result = PyDict_SetItemString(dict, key, constant);
|
||||
Py_DECREF(constant);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
PyMODINIT_FUNC
|
||||
PyInit_elinks(void)
|
||||
{
|
||||
PyObject *elinks_module, *module_dict, *module_name;
|
||||
|
||||
if (set_python_search_path() != 0) return;
|
||||
if (replace_showwarning() != 0) {
|
||||
goto python_error;
|
||||
}
|
||||
|
||||
Py_Initialize();
|
||||
keybindings = PyDict_New();
|
||||
if (!keybindings) {
|
||||
goto python_error;
|
||||
}
|
||||
|
||||
if (!hooks_module_exists()) return;
|
||||
|
||||
if (replace_showwarning() != 0) goto python_error;
|
||||
|
||||
elinks_module = Py_InitModule3("elinks", NULL, module_doc);
|
||||
if (!elinks_module) goto python_error;
|
||||
elinks_module = PyModule_Create(&moduledef);
|
||||
if (!elinks_module) {
|
||||
goto python_error;
|
||||
}
|
||||
|
||||
/* If @elinks_home is NULL, Py_BuildValue() returns a None reference. */
|
||||
if (PyModule_AddObject(elinks_module, "home",
|
||||
Py_BuildValue("s", elinks_home)) != 0)
|
||||
Py_BuildValue("s", elinks_home)) != 0) {
|
||||
goto python_error;
|
||||
}
|
||||
|
||||
python_elinks_err = PyErr_NewException("elinks.error", NULL, NULL);
|
||||
if (!python_elinks_err) goto python_error;
|
||||
|
||||
if (PyModule_AddObject(elinks_module, "error", python_elinks_err) != 0)
|
||||
if (!python_elinks_err) {
|
||||
goto python_error;
|
||||
}
|
||||
|
||||
if (PyModule_AddObject(elinks_module, "error", python_elinks_err) != 0) {
|
||||
goto python_error;
|
||||
}
|
||||
|
||||
module_dict = PyModule_GetDict(elinks_module);
|
||||
if (!module_dict) goto python_error;
|
||||
module_name = PyString_FromString("elinks");
|
||||
if (!module_name) goto python_error;
|
||||
|
||||
if (python_init_dialogs_interface(module_dict, module_name) != 0
|
||||
|| python_init_document_interface(module_dict, module_name) != 0
|
||||
|| python_init_keybinding_interface(module_dict, module_name) != 0
|
||||
|| python_init_load_interface(module_dict, module_name) != 0
|
||||
|| python_init_menu_interface(module_dict, module_name) != 0
|
||||
|| python_init_open_interface(module_dict, module_name) != 0)
|
||||
if (!module_dict) {
|
||||
goto python_error;
|
||||
}
|
||||
|
||||
add_constant(module_dict, "MENU_LINK", PYTHON_MENU_LINK);
|
||||
add_constant(module_dict, "MENU_TAB", PYTHON_MENU_TAB);
|
||||
|
||||
module_name = PyUnicode_FromString("elinks");
|
||||
if (!module_name) {
|
||||
goto python_error;
|
||||
}
|
||||
return elinks_module;
|
||||
|
||||
python_error:
|
||||
alert_python_error();
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
init_python(struct module *module)
|
||||
{
|
||||
if (set_python_search_path() != 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
PyImport_AppendInittab("elinks", PyInit_elinks);
|
||||
|
||||
Py_Initialize();
|
||||
|
||||
if (!hooks_module_exists()) {
|
||||
return;
|
||||
}
|
||||
|
||||
python_hooks = PyImport_ImportModule("hooks");
|
||||
if (!python_hooks) goto python_error;
|
||||
if (!python_hooks) {
|
||||
goto python_error;
|
||||
}
|
||||
|
||||
return;
|
||||
|
||||
@ -335,3 +440,4 @@ add_python_methods(PyObject *dict, PyObject *name, PyMethodDef *methods)
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -21,6 +21,13 @@ typedef int Py_ssize_t;
|
||||
|
||||
struct module;
|
||||
|
||||
enum python_menu_type {
|
||||
PYTHON_MENU_DEFAULT,
|
||||
PYTHON_MENU_LINK,
|
||||
PYTHON_MENU_TAB,
|
||||
PYTHON_MENU_MAX
|
||||
};
|
||||
|
||||
extern struct session *python_ses;
|
||||
extern PyObject *python_elinks_err;
|
||||
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#define PY_SSIZE_T_CLEAN
|
||||
#include <Python.h>
|
||||
|
||||
#include "elinks.h"
|
||||
@ -20,7 +21,7 @@
|
||||
|
||||
/* Python interface for displaying information to the user. */
|
||||
|
||||
static char python_info_box_doc[] =
|
||||
char python_info_box_doc[] =
|
||||
PYTHON_DOCSTRING("info_box(text[, title]) -> None\n\
|
||||
\n\
|
||||
Display information to the user in a dialog box.\n\
|
||||
@ -36,7 +37,7 @@ Optional arguments:\n\
|
||||
title -- A string containing a title for the dialog box. By default\n\
|
||||
the string \"Info\" is used.\n");
|
||||
|
||||
static PyObject *
|
||||
PyObject *
|
||||
python_info_box(PyObject *self, PyObject *args, PyObject *kwargs)
|
||||
{
|
||||
/* [gettext_accelerator_context(python_info_box)] */
|
||||
@ -66,7 +67,7 @@ python_info_box(PyObject *self, PyObject *args, PyObject *kwargs)
|
||||
*/
|
||||
string_object = PyObject_Str(object);
|
||||
if (!string_object) return NULL;
|
||||
text = (unsigned char *) PyString_AS_STRING(string_object);
|
||||
text = (unsigned char *) PyUnicode_AsUTF8(string_object);
|
||||
if (!text) {
|
||||
Py_DECREF(string_object);
|
||||
return NULL;
|
||||
@ -142,7 +143,7 @@ invoke_input_cancel_callback(void *data)
|
||||
|
||||
/* Python interface for getting input from the user. */
|
||||
|
||||
static char python_input_box_doc[] =
|
||||
char python_input_box_doc[] =
|
||||
PYTHON_DOCSTRING(
|
||||
"input_box(prompt, callback, title=\"User dialog\", initial=\"\") -> None\n\
|
||||
\n\
|
||||
@ -163,7 +164,7 @@ title -- A string containing a title for the dialog box. By default\n\
|
||||
initial -- A string containing an initial value for the text entry\n\
|
||||
field. By default the entry field is initially empty.\n");
|
||||
|
||||
static PyObject *
|
||||
PyObject *
|
||||
python_input_box(PyObject *self, PyObject *args, PyObject *kwargs)
|
||||
{
|
||||
unsigned char *prompt;
|
||||
@ -229,21 +230,3 @@ free_prompt:
|
||||
mem_error:
|
||||
return PyErr_NoMemory();
|
||||
}
|
||||
|
||||
static PyMethodDef dialogs_methods[] = {
|
||||
{"info_box", (PyCFunction) python_info_box,
|
||||
METH_VARARGS | METH_KEYWORDS,
|
||||
python_info_box_doc},
|
||||
|
||||
{"input_box", (PyCFunction) python_input_box,
|
||||
METH_VARARGS | METH_KEYWORDS,
|
||||
python_input_box_doc},
|
||||
|
||||
{NULL, NULL, 0, NULL}
|
||||
};
|
||||
|
||||
int
|
||||
python_init_dialogs_interface(PyObject *dict, PyObject *name)
|
||||
{
|
||||
return add_python_methods(dict, name, dialogs_methods);
|
||||
}
|
||||
|
@ -3,6 +3,9 @@
|
||||
|
||||
#include <Python.h>
|
||||
|
||||
int python_init_dialogs_interface(PyObject *dict, PyObject *name);
|
||||
PyObject *python_info_box(PyObject *self, PyObject *args, PyObject *kwargs);
|
||||
extern char python_info_box_doc[];
|
||||
PyObject *python_input_box(PyObject *self, PyObject *args, PyObject *kwargs);
|
||||
extern char python_input_box_doc[];
|
||||
|
||||
#endif
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#define PY_SSIZE_T_CLEAN
|
||||
#include <Python.h>
|
||||
|
||||
#include "elinks.h"
|
||||
@ -16,12 +17,12 @@
|
||||
|
||||
/* Python interface to get the current document's body. */
|
||||
|
||||
static char python_current_document_doc[] =
|
||||
char python_current_document_doc[] =
|
||||
PYTHON_DOCSTRING("current_document() -> string or None\n\
|
||||
\n\
|
||||
If a document is being viewed, return its body; otherwise return None.\n");
|
||||
|
||||
static PyObject *
|
||||
PyObject *
|
||||
python_current_document(PyObject *self, PyObject *args)
|
||||
{
|
||||
if (python_ses && python_ses->doc_view
|
||||
@ -29,7 +30,7 @@ python_current_document(PyObject *self, PyObject *args)
|
||||
struct cache_entry *cached = python_ses->doc_view->document->cached;
|
||||
struct fragment *f = cached ? cached->frag.next : NULL;
|
||||
|
||||
if (f) return PyString_FromStringAndSize(f->data, f->length);
|
||||
if (f) return PyUnicode_FromStringAndSize(f->data, f->length);
|
||||
}
|
||||
|
||||
Py_INCREF(Py_None);
|
||||
@ -38,13 +39,13 @@ python_current_document(PyObject *self, PyObject *args)
|
||||
|
||||
/* Python interface to get the current document's header. */
|
||||
|
||||
static char python_current_header_doc[] =
|
||||
char python_current_header_doc[] =
|
||||
PYTHON_DOCSTRING("current_header() -> string or None\n\
|
||||
\n\
|
||||
If a document is being viewed and it has a header, return the header;\n\
|
||||
otherwise return None.\n");
|
||||
|
||||
static PyObject *
|
||||
PyObject *
|
||||
python_current_header(PyObject *self, PyObject *args)
|
||||
{
|
||||
if (python_ses && python_ses->doc_view
|
||||
@ -52,7 +53,7 @@ python_current_header(PyObject *self, PyObject *args)
|
||||
struct cache_entry *cached = python_ses->doc_view->document->cached;
|
||||
|
||||
if (cached && cached->head)
|
||||
return PyString_FromString(cached->head);
|
||||
return PyUnicode_FromString(cached->head);
|
||||
}
|
||||
|
||||
Py_INCREF(Py_None);
|
||||
@ -61,18 +62,18 @@ python_current_header(PyObject *self, PyObject *args)
|
||||
|
||||
/* Python interface to get the currently-selected link's URL. */
|
||||
|
||||
static char python_current_link_url_doc[] =
|
||||
char python_current_link_url_doc[] =
|
||||
PYTHON_DOCSTRING("current_link_url() -> string or None\n\
|
||||
\n\
|
||||
If a link is selected, return its URL; otherwise return None.\n");
|
||||
|
||||
static PyObject *
|
||||
PyObject *
|
||||
python_current_link_url(PyObject *self, PyObject *args)
|
||||
{
|
||||
unsigned char url[MAX_STR_LEN];
|
||||
|
||||
if (python_ses && get_current_link_url(python_ses, url, MAX_STR_LEN))
|
||||
return PyString_FromString(url);
|
||||
return PyUnicode_FromString(url);
|
||||
|
||||
Py_INCREF(Py_None);
|
||||
return Py_None;
|
||||
@ -80,18 +81,18 @@ python_current_link_url(PyObject *self, PyObject *args)
|
||||
|
||||
/* Python interface to get the current document's title. */
|
||||
|
||||
static char python_current_title_doc[] =
|
||||
char python_current_title_doc[] =
|
||||
PYTHON_DOCSTRING("current_title() -> string or None\n\
|
||||
\n\
|
||||
If a document is being viewed, return its title; otherwise return None.\n");
|
||||
|
||||
static PyObject *
|
||||
PyObject *
|
||||
python_current_title(PyObject *self, PyObject *args)
|
||||
{
|
||||
unsigned char title[MAX_STR_LEN];
|
||||
|
||||
if (python_ses && get_current_title(python_ses, title, MAX_STR_LEN))
|
||||
return PyString_FromString(title);
|
||||
return PyUnicode_FromString(title);
|
||||
|
||||
Py_INCREF(Py_None);
|
||||
return Py_None;
|
||||
@ -99,49 +100,19 @@ python_current_title(PyObject *self, PyObject *args)
|
||||
|
||||
/* Python interface to get the current document's URL. */
|
||||
|
||||
static char python_current_url_doc[] =
|
||||
char python_current_url_doc[] =
|
||||
PYTHON_DOCSTRING("current_url() -> string or None\n\
|
||||
\n\
|
||||
If a document is being viewed, return its URL; otherwise return None.\n");
|
||||
|
||||
static PyObject *
|
||||
PyObject *
|
||||
python_current_url(PyObject *self, PyObject *args)
|
||||
{
|
||||
unsigned char url[MAX_STR_LEN];
|
||||
|
||||
if (python_ses && get_current_url(python_ses, url, MAX_STR_LEN))
|
||||
return PyString_FromString(url);
|
||||
return PyUnicode_FromString(url);
|
||||
|
||||
Py_INCREF(Py_None);
|
||||
return Py_None;
|
||||
}
|
||||
|
||||
static PyMethodDef document_methods[] = {
|
||||
{"current_document", python_current_document,
|
||||
METH_NOARGS,
|
||||
python_current_document_doc},
|
||||
|
||||
{"current_header", python_current_header,
|
||||
METH_NOARGS,
|
||||
python_current_header_doc},
|
||||
|
||||
{"current_link_url", python_current_link_url,
|
||||
METH_NOARGS,
|
||||
python_current_link_url_doc},
|
||||
|
||||
{"current_title", python_current_title,
|
||||
METH_NOARGS,
|
||||
python_current_title_doc},
|
||||
|
||||
{"current_url", python_current_url,
|
||||
METH_NOARGS,
|
||||
python_current_url_doc},
|
||||
|
||||
{NULL, NULL, 0, NULL}
|
||||
};
|
||||
|
||||
int
|
||||
python_init_document_interface(PyObject *dict, PyObject *name)
|
||||
{
|
||||
return add_python_methods(dict, name, document_methods);
|
||||
}
|
||||
|
@ -3,6 +3,15 @@
|
||||
|
||||
#include <Python.h>
|
||||
|
||||
int python_init_document_interface(PyObject *dict, PyObject *name);
|
||||
PyObject *python_current_document(PyObject *self, PyObject *args);
|
||||
extern char python_current_document_doc[];
|
||||
PyObject *python_current_header(PyObject *self, PyObject *args);
|
||||
extern char python_current_header_doc[];
|
||||
PyObject *python_current_link_url(PyObject *self, PyObject *args);
|
||||
extern char python_current_link_url_doc[];
|
||||
PyObject *python_current_title(PyObject *self, PyObject *args);
|
||||
extern char python_current_title_doc[];
|
||||
PyObject *python_current_url(PyObject *self, PyObject *args);
|
||||
extern char python_current_url_doc[];
|
||||
|
||||
#endif
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#define PY_SSIZE_T_CLEAN
|
||||
#include <Python.h>
|
||||
|
||||
#include <stdarg.h>
|
||||
@ -32,9 +33,12 @@ replace_with_python_string(unsigned char **dest, PyObject *object)
|
||||
{
|
||||
unsigned char *str;
|
||||
|
||||
if (object == Py_None) return object;
|
||||
if (object == Py_None) {
|
||||
return object;
|
||||
}
|
||||
|
||||
str = (unsigned char *) PyUnicode_AsUTF8(object);
|
||||
|
||||
str = (unsigned char *) PyString_AsString(object);
|
||||
if (!str) return NULL;
|
||||
|
||||
str = stracpy(str);
|
||||
@ -102,11 +106,13 @@ script_hook_pre_format_html(va_list ap, void *data)
|
||||
if (!result) goto error;
|
||||
|
||||
if (result != Py_None) {
|
||||
unsigned char *str;
|
||||
const unsigned char *str;
|
||||
Py_ssize_t len;
|
||||
|
||||
if (PyString_AsStringAndSize(result, (char **) &str, &len) != 0)
|
||||
str = PyUnicode_AsUTF8AndSize(result, &len);
|
||||
if (!str) {
|
||||
goto error;
|
||||
}
|
||||
|
||||
/* This assumes the Py_ssize_t len is not too large to
|
||||
* fit in the off_t parameter of normalize_cache_entry().
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#define PY_SSIZE_T_CLEAN
|
||||
#include <Python.h>
|
||||
|
||||
#include <stdarg.h>
|
||||
@ -19,7 +20,7 @@
|
||||
#include "util/error.h"
|
||||
#include "util/string.h"
|
||||
|
||||
static PyObject *keybindings = NULL;
|
||||
PyObject *keybindings = NULL;
|
||||
|
||||
/* C wrapper that invokes Python callbacks for bind_key_to_event_name(). */
|
||||
|
||||
@ -58,7 +59,7 @@ keymap_is_valid(const unsigned char *keymap)
|
||||
|
||||
/* Python interface for binding keystrokes to callable objects. */
|
||||
|
||||
static char python_bind_key_doc[] =
|
||||
char python_bind_key_doc[] =
|
||||
PYTHON_DOCSTRING("bind_key(keystroke, callback[, keymap]) -> None\n\
|
||||
\n\
|
||||
Bind a keystroke to a callable object.\n\
|
||||
@ -76,7 +77,7 @@ keymap -- A string containing the name of a keymap. Valid keymap\n\
|
||||
names can be found in the elinkskeys(5) man page. By\n\
|
||||
default the \"main\" keymap is used.\n");
|
||||
|
||||
static PyObject *
|
||||
PyObject *
|
||||
python_bind_key(PyObject *self, PyObject *args, PyObject *kwargs)
|
||||
{
|
||||
const unsigned char *keystroke;
|
||||
@ -174,23 +175,6 @@ rollback:
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static PyMethodDef keybinding_methods[] = {
|
||||
{"bind_key", (PyCFunction) python_bind_key,
|
||||
METH_VARARGS | METH_KEYWORDS,
|
||||
python_bind_key_doc},
|
||||
|
||||
{NULL, NULL, 0, NULL}
|
||||
};
|
||||
|
||||
int
|
||||
python_init_keybinding_interface(PyObject *dict, PyObject *name)
|
||||
{
|
||||
keybindings = PyDict_New();
|
||||
if (!keybindings) return -1;
|
||||
|
||||
return add_python_methods(dict, name, keybinding_methods);
|
||||
}
|
||||
|
||||
void
|
||||
python_done_keybinding_interface(void)
|
||||
{
|
||||
|
@ -3,7 +3,9 @@
|
||||
|
||||
#include <Python.h>
|
||||
|
||||
int python_init_keybinding_interface(PyObject *dict, PyObject *name);
|
||||
extern PyObject *keybindings;
|
||||
PyObject *python_bind_key(PyObject *self, PyObject *args, PyObject *kwargs);
|
||||
extern char python_bind_key_doc[];
|
||||
void python_done_keybinding_interface(void);
|
||||
|
||||
#endif
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#define PY_SSIZE_T_CLEAN
|
||||
#include <Python.h>
|
||||
|
||||
#include "elinks.h"
|
||||
@ -76,7 +77,7 @@ invoke_load_uri_callback(struct download *download, void *data)
|
||||
|
||||
/* Python interface for loading a document. */
|
||||
|
||||
static char python_load_doc[] =
|
||||
char python_load_doc[] =
|
||||
PYTHON_DOCSTRING("load(url, callback) -> None\n\
|
||||
\n\
|
||||
Load a document into the ELinks cache and pass its contents to a\n\
|
||||
@ -91,7 +92,7 @@ callback -- A callable object to be called after the document has\n\
|
||||
if it has no header; the second will be a string representing\n\
|
||||
the document's body, or None if it has no body.\n");
|
||||
|
||||
static PyObject *
|
||||
PyObject *
|
||||
python_load(PyObject *self, PyObject *args)
|
||||
{
|
||||
unsigned char *uristring;
|
||||
@ -150,18 +151,3 @@ mem_error:
|
||||
done_uri(uri);
|
||||
return PyErr_NoMemory();
|
||||
}
|
||||
|
||||
|
||||
static PyMethodDef load_methods[] = {
|
||||
{"load", python_load,
|
||||
METH_VARARGS,
|
||||
python_load_doc},
|
||||
|
||||
{NULL, NULL, 0, NULL}
|
||||
};
|
||||
|
||||
int
|
||||
python_init_load_interface(PyObject *dict, PyObject *name)
|
||||
{
|
||||
return add_python_methods(dict, name, load_methods);
|
||||
}
|
||||
|
@ -3,6 +3,7 @@
|
||||
|
||||
#include <Python.h>
|
||||
|
||||
int python_init_load_interface(PyObject *dict, PyObject *name);
|
||||
PyObject *python_load(PyObject *self, PyObject *args);
|
||||
extern char python_load_doc[];
|
||||
|
||||
#endif
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#define PY_SSIZE_T_CLEAN
|
||||
#include <Python.h>
|
||||
|
||||
#include "elinks.h"
|
||||
@ -43,16 +44,9 @@ invoke_menu_callback(struct terminal *term, void *data, void *ses)
|
||||
python_ses = saved_python_ses;
|
||||
}
|
||||
|
||||
enum python_menu_type {
|
||||
PYTHON_MENU_DEFAULT,
|
||||
PYTHON_MENU_LINK,
|
||||
PYTHON_MENU_TAB,
|
||||
PYTHON_MENU_MAX
|
||||
};
|
||||
|
||||
/* Python interface for displaying simple menus. */
|
||||
|
||||
static char python_menu_doc[] =
|
||||
char python_menu_doc[] =
|
||||
PYTHON_DOCSTRING("menu(items[, type]) -> None\n\
|
||||
\n\
|
||||
Display a menu.\n\
|
||||
@ -74,7 +68,7 @@ type -- A constant specifying the type of menu to display. By default\n\
|
||||
displayed in the same location as the ELinks link menu and is\n\
|
||||
not displayed unless a link is currently selected.\n");
|
||||
|
||||
static PyObject *
|
||||
PyObject *
|
||||
python_menu(PyObject *self, PyObject *args, PyObject *kwargs)
|
||||
{
|
||||
PyObject *items;
|
||||
@ -165,7 +159,7 @@ python_menu(PyObject *self, PyObject *args, PyObject *kwargs)
|
||||
Py_DECREF(tuple);
|
||||
if (!name || !callback) goto error;
|
||||
|
||||
contents = (unsigned char *) PyString_AsString(name);
|
||||
contents = (unsigned char *) PyUnicode_AsUTF8(name);
|
||||
if (!contents) goto error;
|
||||
|
||||
contents = stracpy(contents);
|
||||
@ -210,33 +204,3 @@ error:
|
||||
freeml(ml);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static PyMethodDef menu_methods[] = {
|
||||
{"menu", (PyCFunction) python_menu,
|
||||
METH_VARARGS | METH_KEYWORDS,
|
||||
python_menu_doc},
|
||||
|
||||
{NULL, NULL, 0, NULL}
|
||||
};
|
||||
|
||||
static int
|
||||
add_constant(PyObject *dict, const char *key, int value)
|
||||
{
|
||||
PyObject *constant = PyInt_FromLong(value);
|
||||
int result;
|
||||
|
||||
if (!constant) return -1;
|
||||
result = PyDict_SetItemString(dict, key, constant);
|
||||
Py_DECREF(constant);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
int
|
||||
python_init_menu_interface(PyObject *dict, PyObject *name)
|
||||
{
|
||||
if (add_constant(dict, "MENU_LINK", PYTHON_MENU_LINK) != 0) return -1;
|
||||
if (add_constant(dict, "MENU_TAB", PYTHON_MENU_TAB) != 0) return -1;
|
||||
|
||||
return add_python_methods(dict, name, menu_methods);
|
||||
}
|
||||
|
@ -3,6 +3,7 @@
|
||||
|
||||
#include <Python.h>
|
||||
|
||||
int python_init_menu_interface(PyObject *dict, PyObject *name);
|
||||
PyObject *python_menu(PyObject *self, PyObject *args, PyObject *kwargs);
|
||||
extern char python_menu_doc[];
|
||||
|
||||
#endif
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#define PY_SSIZE_T_CLEAN
|
||||
#include <Python.h>
|
||||
|
||||
#include "elinks.h"
|
||||
@ -17,7 +18,7 @@
|
||||
|
||||
/* Python interface for viewing a document. */
|
||||
|
||||
static char python_open_doc[] =
|
||||
char python_open_doc[] =
|
||||
PYTHON_DOCSTRING("open(url, new_tab=False, background=False) -> None\n\
|
||||
\n\
|
||||
View a document in either the current tab or a new tab.\n\
|
||||
@ -36,7 +37,7 @@ background -- By default a new tab is opened in the foreground. If\n\
|
||||
instead opened in the background. This argument is ignored\n\
|
||||
unless new_tab's value is True.\n");
|
||||
|
||||
static PyObject *
|
||||
PyObject *
|
||||
python_open(PyObject *self, PyObject *args, PyObject *kwargs)
|
||||
{
|
||||
unsigned char *url;
|
||||
@ -76,17 +77,3 @@ python_open(PyObject *self, PyObject *args, PyObject *kwargs)
|
||||
Py_INCREF(Py_None);
|
||||
return Py_None;
|
||||
}
|
||||
|
||||
static PyMethodDef open_methods[] = {
|
||||
{"open", (PyCFunction) python_open,
|
||||
METH_VARARGS | METH_KEYWORDS,
|
||||
python_open_doc},
|
||||
|
||||
{NULL, NULL, 0, NULL}
|
||||
};
|
||||
|
||||
int
|
||||
python_init_open_interface(PyObject *dict, PyObject *name)
|
||||
{
|
||||
return add_python_methods(dict, name, open_methods);
|
||||
}
|
||||
|
@ -3,6 +3,7 @@
|
||||
|
||||
#include <Python.h>
|
||||
|
||||
int python_init_open_interface(PyObject *dict, PyObject *name);
|
||||
PyObject *python_open(PyObject *self, PyObject *args, PyObject *kwargs);
|
||||
extern char python_open_doc[];
|
||||
|
||||
#endif
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#define PY_SSIZE_T_CLEAN
|
||||
#include <Python.h>
|
||||
|
||||
#include "elinks.h"
|
||||
|
Loading…
Reference in New Issue
Block a user