xed/plugin-loaders/python/bindings/xedcommands.override

123 lines
3.0 KiB
Plaintext
Raw Normal View History

2011-11-07 13:46:58 -06:00
%%
headers
#define NO_IMPORT_PYGOBJECT
#define NO_IMPORT_PYGTK
#include <pygobject.h>
#include <pygtk/pygtk.h>
#include "xed-commands.h"
#include "xed-window.h"
2011-11-07 13:46:58 -06:00
void pyxedcommands_register_classes (PyObject *d);
void pyxedcommands_add_constants (PyObject *module, const gchar *strip_prefix);
2011-11-07 13:46:58 -06:00
%%
modulename xed.commands
2011-11-07 13:46:58 -06:00
%%
import xed.Window as PyXedWindow_Type
import xed.Document as PyXedDocument_Type
2011-11-07 13:46:58 -06:00
%%
ignore-glob
_*
%%
override xed_commands_load_uri kwargs
2011-11-07 13:46:58 -06:00
static PyObject *
_wrap_xed_commands_load_uri (PyObject *self, PyObject *args, PyObject *kwargs)
2011-11-07 13:46:58 -06:00
{
static char *kwlist[] = { "window", "uri", "encoding", "line_pos", NULL };
PyGObject *window;
char *uri;
int line_pos = 0;
PyObject *py_encoding = NULL;
XedEncoding *encoding = NULL;
2011-11-07 13:46:58 -06:00
if (!PyArg_ParseTupleAndKeywords (args, kwargs, "O!s|Oi:load_uri",
kwlist, &PyXedWindow_Type,
2011-11-07 13:46:58 -06:00
&window, &uri, &py_encoding,
&line_pos))
return NULL;
if (py_encoding != NULL && py_encoding != Py_None)
{
if (pyg_boxed_check (py_encoding, XED_TYPE_ENCODING))
encoding = pyg_boxed_get (py_encoding, XedEncoding);
2011-11-07 13:46:58 -06:00
else
{
PyErr_SetString (PyExc_TypeError,
"encoding should be a XedEncoding");
2011-11-07 13:46:58 -06:00
return NULL;
}
}
xed_commands_load_uri (XED_WINDOW (window->obj), uri, encoding,
2011-11-07 13:46:58 -06:00
line_pos);
Py_INCREF (Py_None);
return Py_None;
}
%%
override xed_commands_load_uris kwargs
2011-11-07 13:46:58 -06:00
static PyObject *
_wrap_xed_commands_load_uris (PyObject *self, PyObject *args, PyObject *kwargs)
2011-11-07 13:46:58 -06:00
{
static char *kwlist[] = { "window", "uris", "encoding", "line_pos", NULL };
PyGObject *window;
GSList *uris = NULL;
int line_pos = 0;
PyObject *py_encoding = NULL;
PyObject *list;
PyObject *item;
XedEncoding *encoding = NULL;
2011-11-07 13:46:58 -06:00
int len;
int i;
if (!PyArg_ParseTupleAndKeywords (args, kwargs, "O!O|Oi:load_uri",
kwlist, &PyXedWindow_Type,
2011-11-07 13:46:58 -06:00
&window, &list, &py_encoding,
&line_pos))
return NULL;
if (py_encoding != NULL && py_encoding != Py_None)
{
if (pyg_boxed_check (py_encoding, XED_TYPE_ENCODING))
encoding = pyg_boxed_get (py_encoding, XedEncoding);
2011-11-07 13:46:58 -06:00
else {
PyErr_SetString (PyExc_TypeError,
"encoding should be a XedEncoding");
2011-11-07 13:46:58 -06:00
return NULL;
}
}
if (!PySequence_Check (list))
{
PyErr_SetString (PyExc_TypeError,
"second argument must be a sequence");
return NULL;
}
len = PySequence_Length (list);
for (i = 0; i < len; i++)
{
item = PySequence_GetItem (list, i);
Py_DECREF (item);
if (!PyString_Check (item))
{
PyErr_SetString (PyExc_TypeError,
"sequence item not a string");
g_slist_free (uris);
return NULL;
}
uris = g_slist_prepend (uris, PyString_AsString (item));
}
uris = g_slist_reverse (uris);
xed_commands_load_uris (XED_WINDOW (window->obj), uris,
2011-11-07 13:46:58 -06:00
encoding, line_pos);
g_slist_free (uris);
Py_INCREF (Py_None);
return Py_None;
}