2011-06-07 01:37:50 +00:00
|
|
|
/* -*- Mode: C; c-basic-offset: 4 -*- */
|
|
|
|
%%
|
|
|
|
headers
|
|
|
|
#define NO_IMPORT_PYGOBJECT
|
|
|
|
#include <pygobject.h>
|
2011-10-12 11:37:54 +00:00
|
|
|
#include <gst/pygst.h>
|
2011-06-07 01:37:50 +00:00
|
|
|
|
|
|
|
#include <gst/gst.h>
|
|
|
|
#include <ges/ges.h>
|
2011-10-12 11:37:54 +00:00
|
|
|
#include <gst/pygst.h>
|
2011-06-07 01:37:50 +00:00
|
|
|
|
|
|
|
#include <glib.h>
|
|
|
|
#include <pyglib.h>
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include <config.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Boonky define that allows for backwards compatibility with Python 2.4 */
|
|
|
|
#if PY_VERSION_HEX < 0x02050000
|
|
|
|
#define Py_ssize_t int
|
|
|
|
#endif
|
|
|
|
|
2011-06-07 20:55:41 +00:00
|
|
|
void pyges_register_classes(PyObject *d);
|
|
|
|
void pyges_add_constants(PyObject *module, const gchar *strip_prefix);
|
|
|
|
|
2011-06-07 01:37:50 +00:00
|
|
|
%%
|
|
|
|
import gobject.GObject as PyGObject_Type
|
2011-04-25 23:13:38 +00:00
|
|
|
import gobject.MainContext as PyGMainContext_Type
|
|
|
|
import gobject.GObject as PyGInitiallyUnowned_Type
|
|
|
|
import gst.Bin as PyGstBin_Type
|
|
|
|
import gst.Pipeline as PyGstPipeline_Type
|
2011-06-08 01:50:51 +00:00
|
|
|
import gst.Element as PyGstElement_Type
|
|
|
|
import gst.Buffer as PyGstBuffer_Type
|
|
|
|
import gst.Pad as PyGstPad_Type
|
2011-06-06 23:43:42 +00:00
|
|
|
import gst.pbutils.EncodingProfile as PyGstEncodingProfile_Type
|
2011-04-27 11:56:29 +00:00
|
|
|
|
|
|
|
%%
|
|
|
|
override ges_track_get_timeline kwargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_track_get_timeline(PyGObject *self)
|
|
|
|
{
|
|
|
|
const GESTimeline *ret;
|
|
|
|
|
|
|
|
pyg_begin_allow_threads;
|
|
|
|
ret = ges_track_get_timeline(GES_TRACK(self->obj));
|
|
|
|
pyg_end_allow_threads;
|
|
|
|
/* pygobject_new handles NULL checking */
|
|
|
|
return pygobject_new((GObject *)ret);
|
|
|
|
}
|
2011-06-07 17:35:00 +00:00
|
|
|
|
|
|
|
%%
|
2011-06-08 01:50:51 +00:00
|
|
|
override ges_track_get_caps noargs
|
2011-06-07 17:35:00 +00:00
|
|
|
static PyObject *
|
2011-06-06 23:43:42 +00:00
|
|
|
_wrap_ges_track_get_caps(PyGObject *self, void* closure)
|
2011-06-07 17:35:00 +00:00
|
|
|
{
|
2011-06-06 23:43:42 +00:00
|
|
|
const GstCaps *ret;
|
2011-06-07 17:35:00 +00:00
|
|
|
|
2011-06-06 23:43:42 +00:00
|
|
|
ret = ges_track_get_caps(GES_TRACK(self->obj));
|
2011-06-07 17:35:00 +00:00
|
|
|
|
2011-06-06 23:43:42 +00:00
|
|
|
return pyg_boxed_new (GST_TYPE_CAPS, (GstCaps*) ret, TRUE, TRUE);
|
2011-06-08 01:50:51 +00:00
|
|
|
}
|
2011-06-07 17:35:00 +00:00
|
|
|
|
2011-06-08 01:50:51 +00:00
|
|
|
%%
|
2011-06-06 23:43:42 +00:00
|
|
|
override ges_track_set_caps kwargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_track_set_caps(PyGObject *self, PyObject *args, PyObject *kwargs)
|
2011-06-08 01:50:51 +00:00
|
|
|
{
|
2011-06-06 23:43:42 +00:00
|
|
|
static char *kwlist[] = { "caps", NULL };
|
|
|
|
PyObject *py_caps;
|
|
|
|
GstCaps *caps;
|
|
|
|
|
|
|
|
if (!PyArg_ParseTupleAndKeywords(args, kwargs, "O:GstBuffer.set_caps", kwlist, &py_caps))
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
caps = pyg_boxed_get (py_caps, GstCaps);
|
|
|
|
if (PyErr_Occurred())
|
|
|
|
return NULL;
|
|
|
|
|
2011-06-08 01:50:51 +00:00
|
|
|
pyg_begin_allow_threads;
|
|
|
|
ges_track_set_caps (GES_TRACK(self->obj), caps);
|
|
|
|
pyg_end_allow_threads;
|
2011-06-06 23:43:42 +00:00
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
2011-06-08 01:50:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
%%
|
2011-06-06 23:43:42 +00:00
|
|
|
new-constructor GES_TYPE_TRACK
|
|
|
|
%%
|
|
|
|
override ges_track_new kwargs
|
|
|
|
static int
|
|
|
|
_wrap_ges_track_new(PyGObject *self, PyObject *args, PyObject *kwargs)
|
|
|
|
{
|
|
|
|
static char *kwlist[] = { "type", "caps", NULL };
|
|
|
|
PyObject *py_type = NULL;
|
|
|
|
GESTrackType type;
|
|
|
|
GstCaps *caps;
|
|
|
|
PyObject *py_caps;
|
|
|
|
|
|
|
|
if (!PyArg_ParseTupleAndKeywords(args, kwargs,"OO:GES.Track.__init__", kwlist, &py_type, &py_caps))
|
|
|
|
return -1;
|
|
|
|
if (pyg_flags_get_value(GES_TYPE_TRACK_TYPE, py_type, (gpointer)&type))
|
|
|
|
return -1;
|
|
|
|
caps = pyg_boxed_get (py_caps, GstCaps);
|
|
|
|
self->obj = (GObject *)ges_track_new(type, caps);
|
|
|
|
|
|
|
|
if (!self->obj) {
|
|
|
|
PyErr_SetString(PyExc_RuntimeError, "could not create GESTrack object");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
pygobject_register_wrapper((PyObject *)self);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
%%
|
|
|
|
override ges_track_object_lookup_child kwargs
|
2011-06-08 01:50:51 +00:00
|
|
|
static PyObject *
|
2011-06-06 23:43:42 +00:00
|
|
|
_wrap_ges_track_object_lookup_child(PyGObject *self, PyObject *args, PyObject *kwargs)
|
2011-06-08 01:50:51 +00:00
|
|
|
{
|
2011-06-06 23:43:42 +00:00
|
|
|
static char *kwlist[] = {"name", NULL};
|
|
|
|
char *name = NULL;
|
2011-06-08 01:50:51 +00:00
|
|
|
GParamSpec *pspec;
|
|
|
|
GstElement *element;
|
|
|
|
gboolean ret;
|
|
|
|
|
2011-06-06 23:43:42 +00:00
|
|
|
if (!PyArg_ParseTupleAndKeywords(args, kwargs,
|
|
|
|
"z:GES.TrackObject.lookup_child", kwlist, &name))
|
|
|
|
return FALSE;
|
|
|
|
|
2011-06-08 01:50:51 +00:00
|
|
|
pyg_begin_allow_threads;
|
|
|
|
ret = ges_track_object_lookup_child (GES_TRACK_OBJECT (self->obj), name, &element, &pspec);
|
|
|
|
pyg_end_allow_threads;
|
|
|
|
|
2011-06-06 23:43:42 +00:00
|
|
|
if (!ret)
|
|
|
|
return PyBool_FromLong(ret);
|
|
|
|
return pygobject_new((GObject *)element);
|
2011-06-07 17:35:00 +00:00
|
|
|
}
|
|
|
|
|
2011-05-14 02:32:45 +00:00
|
|
|
%%
|
|
|
|
override ges_timeline_parse_launch_effect_new kwargs
|
|
|
|
static int
|
|
|
|
_wrap_ges_timeline_parse_launch_effect_new(PyGObject *self, PyObject *args, PyObject *kwargs)
|
|
|
|
{
|
|
|
|
static char *kwlist[] = { "video_bin_description", "audio_bin_description", NULL };
|
|
|
|
char *video_bin_description, *audio_bin_description = NULL;
|
|
|
|
|
|
|
|
if (!PyArg_ParseTupleAndKeywords(args, kwargs,"zz:GES.TimelineParseLaunchEffect.__init__", kwlist, &video_bin_description, &audio_bin_description))
|
|
|
|
return -1;
|
|
|
|
self->obj = (GObject *)ges_timeline_parse_launch_effect_new(video_bin_description, audio_bin_description);
|
|
|
|
|
|
|
|
if (!self->obj) {
|
|
|
|
PyErr_SetString(PyExc_RuntimeError, "could not create GESTimelineParseLaunchEffect object");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
pygobject_register_wrapper((PyObject *)self);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2011-06-08 01:50:51 +00:00
|
|
|
/* I did not override ges_formatter_get_data and set_data for these functions are deprecated */
|
|
|
|
|
2012-01-04 21:06:37 +00:00
|
|
|
%%
|
|
|
|
override ges_pitivi_formatter_set_sources kwargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_pitivi_formatter_set_sources(PyGObject *self, PyObject *args, PyObject *kwargs)
|
|
|
|
{
|
|
|
|
GList *sources = NULL;
|
|
|
|
guint i;
|
|
|
|
|
|
|
|
PyObject *pylist = NULL;
|
|
|
|
PyGObject *tmpobj = NULL;
|
|
|
|
Py_ssize_t list_size;
|
|
|
|
|
|
|
|
GESPitiviFormatter *formatter = GES_PITIVI_FORMATTER (self->obj);
|
|
|
|
|
|
|
|
if (!PyArg_ParseTuple(args, "O:GESPitiviFormatter.set_sources",
|
|
|
|
&pylist))
|
|
|
|
return PyBool_FromLong(FALSE);
|
|
|
|
|
|
|
|
list_size = PyList_GET_SIZE(pylist);
|
|
|
|
|
|
|
|
for (i = 0; i < list_size; i++) {
|
|
|
|
tmpobj = (PyGObject*)PyList_GetItem(pylist, i);
|
|
|
|
sources = g_list_prepend (sources, tmpobj->obj);
|
|
|
|
}
|
|
|
|
|
|
|
|
return PyBool_FromLong (ges_pitivi_formatter_set_sources (formatter, sources));
|
|
|
|
}
|
|
|
|
|
2012-01-03 10:59:29 +00:00
|
|
|
%%
|
|
|
|
override ges_pitivi_formatter_get_sources kwargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_pitivi_formatter_get_sources(PyGObject *self, PyObject *args, PyObject *kwargs)
|
|
|
|
{
|
|
|
|
const GList *l, *list;
|
|
|
|
PyObject *py_list;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GES_IS_PITIVI_FORMATTER (self->obj),PyList_New(0));
|
|
|
|
|
|
|
|
pyg_begin_allow_threads;
|
2012-01-04 22:04:53 +00:00
|
|
|
list = ges_pitivi_formatter_get_sources (GES_PITIVI_FORMATTER (self->obj));
|
2012-01-03 10:59:29 +00:00
|
|
|
pyg_end_allow_threads;
|
|
|
|
|
|
|
|
py_list = PyList_New(0);
|
|
|
|
for (l = list; l; l = l->next) {
|
2012-01-04 22:04:53 +00:00
|
|
|
gchar * source = (gchar *)l->data;
|
|
|
|
GST_ERROR ("Adding %s", source);
|
|
|
|
PyList_Append(py_list, PyString_FromString(source));
|
|
|
|
Py_DECREF(source);
|
2012-01-03 10:59:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return py_list;
|
|
|
|
}
|
|
|
|
|
2011-06-08 01:50:51 +00:00
|
|
|
%%
|
|
|
|
override ges_timeline_object_get_top_effects noargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_timeline_object_get_top_effects(PyGObject *self)
|
|
|
|
{
|
|
|
|
const GList *l, *list;
|
|
|
|
PyObject *py_list;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GES_IS_TIMELINE_OBJECT (self->obj),PyList_New(0));
|
|
|
|
|
|
|
|
pyg_begin_allow_threads;
|
|
|
|
list = ges_timeline_object_get_top_effects(GES_TIMELINE_OBJECT(self->obj));
|
|
|
|
pyg_end_allow_threads;
|
|
|
|
|
|
|
|
py_list = PyList_New(0);
|
|
|
|
for (l = list; l; l = l->next) {
|
|
|
|
GESTrackEffect *track_effect = (GESTrackEffect*)l->data;
|
|
|
|
PyObject *py_track_effect = pygobject_new(G_OBJECT(track_effect));
|
|
|
|
PyList_Append(py_list, py_track_effect);
|
|
|
|
Py_DECREF(py_track_effect);
|
|
|
|
}
|
|
|
|
|
|
|
|
return py_list;
|
|
|
|
}
|
|
|
|
|
|
|
|
%%
|
|
|
|
override ges_timeline_get_tracks noargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_timeline_get_tracks(PyGObject *self)
|
|
|
|
{
|
|
|
|
const GList *l, *list;
|
|
|
|
PyObject *py_list;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GES_IS_TIMELINE (self->obj),PyList_New(0));
|
|
|
|
|
|
|
|
pyg_begin_allow_threads;
|
|
|
|
list = ges_timeline_get_tracks(GES_TIMELINE(self->obj));
|
|
|
|
pyg_end_allow_threads;
|
|
|
|
|
|
|
|
py_list = PyList_New(0);
|
|
|
|
for (l = list; l; l = l->next) {
|
|
|
|
GESTrack *track = (GESTrack*)l->data;
|
|
|
|
PyObject *py_track = pygobject_new(G_OBJECT(track));
|
|
|
|
PyList_Append(py_list, py_track);
|
|
|
|
Py_DECREF(py_track);
|
|
|
|
}
|
|
|
|
|
|
|
|
return py_list;
|
|
|
|
}
|
|
|
|
|
2011-06-07 17:35:00 +00:00
|
|
|
%%
|
|
|
|
override ges_timeline_get_layers noargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_timeline_get_layers(PyGObject *self)
|
|
|
|
{
|
|
|
|
const GList *l, *list;
|
|
|
|
PyObject *py_list;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GES_IS_TIMELINE (self->obj), PyList_New(0));
|
|
|
|
|
|
|
|
pyg_begin_allow_threads;
|
|
|
|
list = ges_timeline_get_layers(GES_TIMELINE(self->obj));
|
|
|
|
pyg_end_allow_threads;
|
|
|
|
|
|
|
|
py_list = PyList_New(0);
|
|
|
|
for (l = list; l; l = l->next) {
|
|
|
|
GESTimelineLayer *layer = (GESTimelineLayer*)l->data;
|
|
|
|
PyObject *py_layer = pygobject_new(G_OBJECT(layer));
|
|
|
|
PyList_Append(py_list, py_layer);
|
|
|
|
Py_DECREF(py_layer);
|
|
|
|
}
|
|
|
|
|
|
|
|
return py_list;
|
|
|
|
}
|
|
|
|
|
|
|
|
%%
|
|
|
|
override ges_timeline_layer_get_objects noargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_timeline_layer_get_objects(PyGObject *self)
|
|
|
|
{
|
|
|
|
const GList *l, *list;
|
|
|
|
PyObject *py_list;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GES_IS_TIMELINE_LAYER (self->obj), PyList_New(0));
|
|
|
|
|
|
|
|
pyg_begin_allow_threads;
|
|
|
|
list = ges_timeline_layer_get_objects(GES_TIMELINE_LAYER(self->obj));
|
|
|
|
pyg_end_allow_threads;
|
|
|
|
|
|
|
|
py_list = PyList_New(0);
|
|
|
|
for (l = list; l; l = l->next) {
|
|
|
|
GESTimelineObject *object = (GESTimelineObject*)l->data;
|
|
|
|
PyObject *py_object = pygobject_new(G_OBJECT(object));
|
|
|
|
PyList_Append(py_list, py_object);
|
|
|
|
Py_DECREF(py_object);
|
|
|
|
}
|
|
|
|
|
|
|
|
return py_list;
|
|
|
|
}
|
|
|
|
|
|
|
|
%%
|
|
|
|
override ges_timeline_object_get_track_objects noargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_timeline_object_get_track_objects(PyGObject *self)
|
|
|
|
{
|
|
|
|
const GList *l, *list;
|
|
|
|
PyObject *py_list;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GES_IS_TIMELINE_OBJECT (self->obj), PyList_New(0));
|
|
|
|
|
|
|
|
pyg_begin_allow_threads;
|
|
|
|
list = ges_timeline_object_get_track_objects(GES_TIMELINE_OBJECT(self->obj));
|
|
|
|
pyg_end_allow_threads;
|
|
|
|
|
|
|
|
py_list = PyList_New(0);
|
|
|
|
for (l = list; l; l = l->next) {
|
|
|
|
GESTrackObject *object = (GESTrackObject*)l->data;
|
2011-07-13 16:30:06 +00:00
|
|
|
PyObject *py_object = pygobject_new(G_OBJECT(object));
|
|
|
|
PyList_Append(py_list, py_object);
|
|
|
|
Py_DECREF(py_object);
|
|
|
|
}
|
|
|
|
|
|
|
|
return py_list;
|
|
|
|
}
|
|
|
|
|
|
|
|
%%
|
|
|
|
override ges_track_get_objects noargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_track_get_objects(PyGObject *self)
|
|
|
|
{
|
|
|
|
const GList *l, *list;
|
|
|
|
PyObject *py_list;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GES_IS_TRACK (self->obj), PyList_New(0));
|
|
|
|
|
|
|
|
pyg_begin_allow_threads;
|
|
|
|
list = ges_track_get_objects(GES_TRACK(self->obj));
|
|
|
|
pyg_end_allow_threads;
|
|
|
|
|
|
|
|
py_list = PyList_New(0);
|
|
|
|
for (l = list; l; l = l->next) {
|
|
|
|
GESTrackObject *object = (GESTrackObject*)l->data;
|
2011-06-07 17:35:00 +00:00
|
|
|
PyObject *py_object = pygobject_new(G_OBJECT(object));
|
|
|
|
PyList_Append(py_list, py_object);
|
|
|
|
Py_DECREF(py_object);
|
|
|
|
}
|
|
|
|
|
|
|
|
return py_list;
|
|
|
|
}
|
2011-06-07 22:05:43 +00:00
|
|
|
|
2011-06-08 01:50:51 +00:00
|
|
|
%%
|
|
|
|
override ges_track_object_get_child_property kwargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_track_object_get_child_property (PyGObject *self, PyObject *args, PyObject *kwargs)
|
|
|
|
{
|
|
|
|
gchar *property_name;
|
|
|
|
GESTrackObject *obj = GES_TRACK_OBJECT (self->obj);
|
|
|
|
|
|
|
|
GParamSpec *pspec = NULL;
|
|
|
|
GValue value = { 0, } ;
|
|
|
|
PyObject *ret;
|
|
|
|
|
|
|
|
if (!PyArg_ParseTuple(args, "s:GESTrackObject.get_child_property",
|
|
|
|
&property_name)) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
ges_track_object_lookup_child(obj, property_name, NULL, &pspec);
|
|
|
|
if (!pspec) {
|
|
|
|
gchar buf[512];
|
|
|
|
g_snprintf(buf, sizeof(buf),
|
|
|
|
"container does not support property `%s'",
|
|
|
|
property_name);
|
|
|
|
|
|
|
|
PyErr_SetString(PyExc_TypeError, buf);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
g_value_init(&value, G_PARAM_SPEC_VALUE_TYPE(pspec));
|
|
|
|
|
|
|
|
ges_track_object_get_child_property_by_pspec(obj,
|
|
|
|
pspec,
|
|
|
|
&value);
|
|
|
|
|
|
|
|
ret = pyg_value_as_pyobject(&value, TRUE);
|
|
|
|
g_value_unset(&value);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2011-06-06 23:43:42 +00:00
|
|
|
%%
|
|
|
|
override ges_track_object_set_child_property kwargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_track_object_set_child_property (PyGObject *self, PyObject *args, PyObject *kwargs)
|
|
|
|
{
|
|
|
|
gchar *property_name;
|
|
|
|
GESTrackObject *obj = GES_TRACK_OBJECT (self->obj);
|
|
|
|
|
|
|
|
GParamSpec *pspec = NULL;
|
|
|
|
PyGObject *pyvalue;
|
|
|
|
GValue value = { 0, } ;
|
|
|
|
|
|
|
|
if (!PyArg_ParseTuple(args, "sO:GESTrackObject.set_child_property",
|
|
|
|
&property_name, &pyvalue)) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
ges_track_object_lookup_child(obj, property_name, NULL, &pspec);
|
|
|
|
if (!pspec) {
|
|
|
|
gchar buf[512];
|
|
|
|
g_snprintf(buf, sizeof(buf),
|
|
|
|
"container does not support property `%s'",
|
|
|
|
property_name);
|
|
|
|
|
|
|
|
PyErr_SetString(PyExc_TypeError, buf);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
g_value_init(&value, G_PARAM_SPEC_VALUE_TYPE(pspec));
|
|
|
|
pyg_value_from_pyobject(&value, (PyObject*)pyvalue);
|
|
|
|
|
|
|
|
ges_track_object_set_child_property_by_pspec(obj,
|
|
|
|
pspec,
|
|
|
|
&value);
|
|
|
|
|
|
|
|
g_value_unset(&value);
|
|
|
|
|
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
|
|
|
}
|
|
|
|
|
|
|
|
%%
|
|
|
|
override ges_track_object_list_children_properties noargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_track_object_list_children_properties (PyGObject *self)
|
|
|
|
{
|
|
|
|
GParamSpec **specs;
|
|
|
|
PyObject *list;
|
|
|
|
guint nprops;
|
|
|
|
guint i;
|
|
|
|
|
|
|
|
specs = ges_track_object_list_children_properties(GES_TRACK_OBJECT (self->obj), &nprops);
|
|
|
|
list = PyTuple_New(nprops);
|
|
|
|
if (list == NULL) {
|
|
|
|
g_free(specs);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < nprops; i++) {
|
|
|
|
PyTuple_SetItem(list, i, pyg_param_spec_new(specs[i]));
|
|
|
|
}
|
|
|
|
|
|
|
|
g_free(specs);
|
|
|
|
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
2011-12-26 01:54:29 +00:00
|
|
|
%%
|
|
|
|
override ges_version noargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_version (PyObject *self)
|
|
|
|
{
|
|
|
|
guint major, minor, micro, nano;
|
|
|
|
PyObject *py_tuple;
|
|
|
|
|
|
|
|
ges_version (&major, &minor, µ, &nano);
|
|
|
|
py_tuple = PyTuple_New(4);
|
|
|
|
PyTuple_SetItem(py_tuple, 0, PyInt_FromLong(major));
|
|
|
|
PyTuple_SetItem(py_tuple, 1, PyInt_FromLong(minor));
|
|
|
|
PyTuple_SetItem(py_tuple, 2, PyInt_FromLong(micro));
|
|
|
|
PyTuple_SetItem(py_tuple, 3, PyInt_FromLong(nano));
|
|
|
|
|
|
|
|
return py_tuple;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-02-10 19:58:14 +00:00
|
|
|
%%
|
|
|
|
override ges_track_object_edit kwargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_track_object_edit (PyGObject *self, PyObject *args, PyObject *kwargs)
|
|
|
|
{
|
|
|
|
GList *layers = NULL;
|
|
|
|
GESEditMode mode;
|
|
|
|
GESEdge edge;
|
|
|
|
guint64 position;
|
|
|
|
guint i;
|
|
|
|
gboolean ret;
|
|
|
|
|
|
|
|
PyObject *py_position = NULL;
|
|
|
|
PyObject *list = NULL, *pymode = NULL, *pyedge = NULL;
|
|
|
|
PyGObject *tmpobj = NULL;
|
|
|
|
Py_ssize_t list_size;
|
|
|
|
|
|
|
|
GESTrackObject *tckobj = GES_TRACK_OBJECT (self->obj);
|
|
|
|
|
|
|
|
if (!PyArg_ParseTuple(args, "OOOl:GESTrackObject.edit",
|
|
|
|
&list, &pymode, &pyedge, &py_position))
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
position = PyLong_AsUnsignedLongLong(py_position);
|
|
|
|
|
|
|
|
list_size = PyList_GET_SIZE(list);
|
|
|
|
|
|
|
|
for (i = 0; i < list_size; i++) {
|
|
|
|
tmpobj = (PyGObject*)PyList_GetItem(list, i);
|
|
|
|
layers = g_list_prepend (layers, GES_TIMELINE_LAYER (tmpobj->obj));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pyg_enum_get_value(GES_TYPE_EDIT_MODE, pymode, (gpointer)&mode))
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
if (pyg_enum_get_value(GES_TYPE_EDGE, pyedge, (gpointer)&edge))
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
ret = ges_track_object_edit (tckobj, layers, mode, edge, position);
|
|
|
|
|
|
|
|
return PyBool_FromLong(ret);
|
|
|
|
}
|
|
|
|
|
|
|
|
%%
|
|
|
|
override ges_timeline_object_edit kwargs
|
|
|
|
static PyObject *
|
|
|
|
_wrap_ges_timeline_object_edit (PyGObject *self, PyObject *args, PyObject *kwargs)
|
|
|
|
{
|
|
|
|
GList *layers = NULL;
|
|
|
|
GESEditMode mode;
|
|
|
|
GESEdge edge;
|
|
|
|
gint64 position;
|
|
|
|
guint move_layer, i;
|
|
|
|
gboolean ret;
|
|
|
|
|
|
|
|
PyObject *py_position = NULL;
|
|
|
|
PyObject *list = NULL, *pymode = NULL, *pyedge = NULL;
|
|
|
|
PyGObject *tmpobj = NULL;
|
|
|
|
Py_ssize_t list_size;
|
|
|
|
|
|
|
|
GESTimelineObject *tlobj = GES_TIMELINE_OBJECT (self->obj);
|
|
|
|
|
|
|
|
if (!PyArg_ParseTuple(args, "OiOOO:GESTimelineObject.edit",
|
|
|
|
&list, &move_layer, &pymode, &pyedge, &py_position))
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
position = PyLong_AsUnsignedLongLong(py_position);
|
|
|
|
|
|
|
|
list_size = PyList_GET_SIZE(list);
|
|
|
|
|
|
|
|
for (i = 0; i < list_size; i++) {
|
|
|
|
tmpobj = (PyGObject*)PyList_GetItem(list, i);
|
|
|
|
layers = g_list_prepend (layers, GES_TIMELINE_LAYER (tmpobj->obj));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pyg_enum_get_value(GES_TYPE_EDIT_MODE, pymode, (gpointer)&mode))
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
if (pyg_enum_get_value(GES_TYPE_EDGE, pyedge, (gpointer)&edge))
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
ret = ges_timeline_object_edit (tlobj, layers, move_layer, mode, edge, position);
|
|
|
|
|
|
|
|
return PyBool_FromLong(ret);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-06-07 22:05:43 +00:00
|
|
|
%%
|
|
|
|
ignore-glob
|
|
|
|
|
|
|
|
*_get_type
|
2011-06-07 17:59:16 +00:00
|
|
|
ges_formatter_set_data
|
|
|
|
ges_formatter_set_data
|
2011-06-05 23:02:17 +00:00
|
|
|
*_valist
|
|
|
|
*_by_pspec
|