Rename GESTrackParseLaunchEffect to GESEffect

This commit is contained in:
Thibault Saunier 2013-01-26 12:40:51 -03:00
parent 5da8fa89e2
commit e24cccabfd
18 changed files with 178 additions and 191 deletions

View file

@ -72,7 +72,7 @@ platform as well as Windows. It is released under the GNU Library General Public
<xi:include href="xml/ges-track-video-transition.xml"/> <xi:include href="xml/ges-track-video-transition.xml"/>
<xi:include href="xml/ges-track-audio-transition.xml"/> <xi:include href="xml/ges-track-audio-transition.xml"/>
<xi:include href="xml/ges-track-image-source.xml"/> <xi:include href="xml/ges-track-image-source.xml"/>
<xi:include href="xml/ges-track-parse-launch-effect.xml"/> <xi:include href="xml/ges-effect.xml"/>
</chapter> </chapter>
<chapter> <chapter>

View file

@ -868,20 +868,20 @@ ges_base_effect_get_type
</SECTION> </SECTION>
<SECTION> <SECTION>
<FILE>ges-track-parse-launch-effect</FILE> <FILE>ges-effect</FILE>
<TITLE>GESTrackParseLaunchEffect</TITLE> <TITLE>GESEffect</TITLE>
GESTrackParseLaunchEffect GESEffect
ges_track_parse_launch_effect_new ges_effect_new
<SUBSECTION Standard> <SUBSECTION Standard>
GESTrackParseLaunchEffectClass GESEffectClass
GESTrackParseLaunchEffectPrivate GESEffectPrivate
GES_IS_TRACK_PARSE_LAUNCH_EFFECT GES_IS_EFFECT
GES_IS_TRACK_PARSE_LAUNCH_EFFECT_CLASS GES_IS_EFFECT_CLASS
GES_TRACK_PARSE_LAUNCH_EFFECT GES_EFFECT
GES_TRACK_PARSE_LAUNCH_EFFECT_CLASS GES_EFFECT_CLASS
GES_TRACK_PARSE_LAUNCH_EFFECT_GET_CLASS GES_EFFECT_GET_CLASS
GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT GES_TYPE_EFFECT
ges_track_parse_launch_effect_get_type ges_effect_get_type
</SECTION> </SECTION>
<SECTION> <SECTION>

View file

@ -28,7 +28,7 @@ ges_track_get_type
ges_track_image_source_get_type ges_track_image_source_get_type
ges_track_element_get_type ges_track_element_get_type
ges_base_effect_get_type ges_base_effect_get_type
ges_track_parse_launch_effect_get_type ges_effect_get_type
ges_track_operation_get_type ges_track_operation_get_type
ges_track_source_get_type ges_track_source_get_type
ges_track_text_overlay_get_type ges_track_text_overlay_get_type

View file

@ -43,7 +43,7 @@ libges_@GST_API_VERSION@_la_SOURCES = \
ges-track-title-source.c \ ges-track-title-source.c \
ges-track-text-overlay.c \ ges-track-text-overlay.c \
ges-base-effect.c \ ges-base-effect.c \
ges-track-parse-launch-effect.c \ ges-effect.c \
ges-screenshot.c \ ges-screenshot.c \
ges-formatter.c \ ges-formatter.c \
ges-pitivi-formatter.c \ ges-pitivi-formatter.c \
@ -84,7 +84,7 @@ libges_@GST_API_VERSION@include_HEADERS = \
ges-overlay-clip.h \ ges-overlay-clip.h \
ges-text-overlay-clip.h \ ges-text-overlay-clip.h \
ges-base-effect.h \ ges-base-effect.h \
ges-track-parse-launch-effect.h \ ges-effect.h \
ges-track.h \ ges-track.h \
ges-track-element.h \ ges-track-element.h \
ges-track-source.h \ ges-track-source.h \

View file

@ -31,13 +31,13 @@
* *
* |[ * |[
* GESAsset *effect_asset; * GESAsset *effect_asset;
* GESTrackParseLaunchEffect *effect; * GESEffect *effect;
* *
* // You create an asset for an effect * // You create an asset for an effect
* effect_asset = ges_asset_request (GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, "agingtv", NULL); * effect_asset = ges_asset_request (GES_TYPE_EFFECT, "agingtv", NULL);
* *
* // And now you can extract an instance of GESTrackParseLaunchEffect from that asset * // And now you can extract an instance of GESEffect from that asset
* effect = GES_TRACK_PARSE_LAUNCH_EFFECT (ges_asset_extract (effect_asset)); * effect = GES_EFFECT (ges_asset_extract (effect_asset));
* *
* ]| * ]|
* *
@ -53,7 +53,7 @@
* the documentation of each type to know what the ID of #GESAsset actually represents for that type. By default, * the documentation of each type to know what the ID of #GESAsset actually represents for that type. By default,
* we only have one #GESAsset per type, and the @id is the name of the type, but this behaviour is overriden * we only have one #GESAsset per type, and the @id is the name of the type, but this behaviour is overriden
* to be more usefull. For example, for GESTransitionClips, the ID is the vtype of the transition * to be more usefull. For example, for GESTransitionClips, the ID is the vtype of the transition
* you will extract from it (ie crossfade, box-wipe-rc etc..) For #GESTrackParseLaunchEffect the id is the * you will extract from it (ie crossfade, box-wipe-rc etc..) For #GESEffect the id is the
* @bin-description property of the extracted objects (ie the gst-launch style description of the bin that * @bin-description property of the extracted objects (ie the gst-launch style description of the bin that
* will be used). * will be used).
* *
@ -789,7 +789,7 @@ done:
* new asset. The class must implement the #GESExtractable interface. * new asset. The class must implement the #GESExtractable interface.
* @id: The Identifier of the asset we want to create. This identifier depends of the extractable, * @id: The Identifier of the asset we want to create. This identifier depends of the extractable,
* type you want. By default it is the name of the class itself (or %NULL), but for example for a * type you want. By default it is the name of the class itself (or %NULL), but for example for a
* GESTrackParseLaunchEffect, it will be the pipeline description, for a GESUriClip it * GESEffect, it will be the pipeline description, for a GESUriClip it
* will be the name of the file, etc... You should refer to the documentation of the #GESExtractable * will be the name of the file, etc... You should refer to the documentation of the #GESExtractable
* type you want to create a #GESAsset for. * type you want to create a #GESAsset for.
* @cancellable: (allow-none): optional %GCancellable object, %NULL to ignore. * @cancellable: (allow-none): optional %GCancellable object, %NULL to ignore.

View file

@ -170,7 +170,7 @@ ges_tl_parse_launch_effect_create_track_obj (GESClip * self, GESTrackType type)
if (bin_description) { if (bin_description) {
/* FIXME Work with a GESAsset here! */ /* FIXME Work with a GESAsset here! */
return g_object_new (GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, "bin-description", return g_object_new (GES_TYPE_EFFECT, "bin-description",
bin_description, "track-type", type, NULL); bin_description, "track-type", type, NULL);
} }

View file

@ -18,7 +18,7 @@
*/ */
/** /**
* SECTION:ges-track-parse-launch-effect * SECTION:ges-effect
* @short_description: adds an effect build from a parse-launch style * @short_description: adds an effect build from a parse-launch style
* bin description to a stream in a #GESSourceClip or a #GESTimelineLayer * bin description to a stream in a #GESSourceClip or a #GESTimelineLayer
*/ */
@ -27,21 +27,20 @@
#include "ges-extractable.h" #include "ges-extractable.h"
#include "ges-track-element.h" #include "ges-track-element.h"
#include "ges-base-effect.h" #include "ges-base-effect.h"
#include "ges-track-parse-launch-effect.h" #include "ges-effect.h"
static void ges_extractable_interface_init (GESExtractableInterface * iface); static void ges_extractable_interface_init (GESExtractableInterface * iface);
G_DEFINE_TYPE_WITH_CODE (GESTrackParseLaunchEffect, G_DEFINE_TYPE_WITH_CODE (GESEffect,
ges_track_parse_launch_effect, GES_TYPE_BASE_EFFECT, ges_effect, GES_TYPE_BASE_EFFECT,
G_IMPLEMENT_INTERFACE (GES_TYPE_EXTRACTABLE, G_IMPLEMENT_INTERFACE (GES_TYPE_EXTRACTABLE,
ges_extractable_interface_init)); ges_extractable_interface_init));
static void ges_track_parse_launch_effect_dispose (GObject * object); static void ges_effect_dispose (GObject * object);
static void ges_track_parse_launch_effect_finalize (GObject * object); static void ges_effect_finalize (GObject * object);
static GstElement *ges_track_parse_launch_effect_create_element (GESTrackElement static GstElement *ges_effect_create_element (GESTrackElement * self);
* self);
struct _GESTrackParseLaunchEffectPrivate struct _GESEffectPrivate
{ {
gchar *bin_description; gchar *bin_description;
}; };
@ -81,7 +80,7 @@ extractable_get_parameters_from_id (const gchar * id, guint * n_params)
static gchar * static gchar *
extractable_get_id (GESExtractable * self) extractable_get_id (GESExtractable * self)
{ {
return g_strdup (GES_TRACK_PARSE_LAUNCH_EFFECT (self)->priv->bin_description); return g_strdup (GES_EFFECT (self)->priv->bin_description);
} }
static void static void
@ -93,11 +92,10 @@ ges_extractable_interface_init (GESExtractableInterface * iface)
} }
static void static void
ges_track_parse_launch_effect_get_property (GObject * object, ges_effect_get_property (GObject * object,
guint property_id, GValue * value, GParamSpec * pspec) guint property_id, GValue * value, GParamSpec * pspec)
{ {
GESTrackParseLaunchEffectPrivate *priv = GESEffectPrivate *priv = GES_EFFECT (object)->priv;
GES_TRACK_PARSE_LAUNCH_EFFECT (object)->priv;
switch (property_id) { switch (property_id) {
case PROP_BIN_DESCRIPTION: case PROP_BIN_DESCRIPTION:
@ -109,10 +107,10 @@ ges_track_parse_launch_effect_get_property (GObject * object,
} }
static void static void
ges_track_parse_launch_effect_set_property (GObject * object, ges_effect_set_property (GObject * object,
guint property_id, const GValue * value, GParamSpec * pspec) guint property_id, const GValue * value, GParamSpec * pspec)
{ {
GESTrackParseLaunchEffect *self = GES_TRACK_PARSE_LAUNCH_EFFECT (object); GESEffect *self = GES_EFFECT (object);
switch (property_id) { switch (property_id) {
case PROP_BIN_DESCRIPTION: case PROP_BIN_DESCRIPTION:
@ -124,8 +122,7 @@ ges_track_parse_launch_effect_set_property (GObject * object,
} }
static void static void
ges_track_parse_launch_effect_class_init (GESTrackParseLaunchEffectClass * ges_effect_class_init (GESEffectClass * klass)
klass)
{ {
GObjectClass *object_class; GObjectClass *object_class;
GESTrackElementClass *obj_bg_class; GESTrackElementClass *obj_bg_class;
@ -133,17 +130,17 @@ ges_track_parse_launch_effect_class_init (GESTrackParseLaunchEffectClass *
object_class = G_OBJECT_CLASS (klass); object_class = G_OBJECT_CLASS (klass);
obj_bg_class = GES_TRACK_ELEMENT_CLASS (klass); obj_bg_class = GES_TRACK_ELEMENT_CLASS (klass);
g_type_class_add_private (klass, sizeof (GESTrackParseLaunchEffectPrivate)); g_type_class_add_private (klass, sizeof (GESEffectPrivate));
object_class->get_property = ges_track_parse_launch_effect_get_property; object_class->get_property = ges_effect_get_property;
object_class->set_property = ges_track_parse_launch_effect_set_property; object_class->set_property = ges_effect_set_property;
object_class->dispose = ges_track_parse_launch_effect_dispose; object_class->dispose = ges_effect_dispose;
object_class->finalize = ges_track_parse_launch_effect_finalize; object_class->finalize = ges_effect_finalize;
obj_bg_class->create_element = ges_track_parse_launch_effect_create_element; obj_bg_class->create_element = ges_effect_create_element;
/** /**
* GESTrackParseLaunchEffect:bin-description: * GESEffect:bin-description:
* *
* The description of the effect bin with a gst-launch-style * The description of the effect bin with a gst-launch-style
* pipeline description. * pipeline description.
@ -158,39 +155,37 @@ ges_track_parse_launch_effect_class_init (GESTrackParseLaunchEffectClass *
} }
static void static void
ges_track_parse_launch_effect_init (GESTrackParseLaunchEffect * self) ges_effect_init (GESEffect * self)
{ {
self->priv = self->priv =
G_TYPE_INSTANCE_GET_PRIVATE (self, GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, G_TYPE_INSTANCE_GET_PRIVATE (self, GES_TYPE_EFFECT, GESEffectPrivate);
GESTrackParseLaunchEffectPrivate);
} }
static void static void
ges_track_parse_launch_effect_dispose (GObject * object) ges_effect_dispose (GObject * object)
{ {
G_OBJECT_CLASS (ges_track_parse_launch_effect_parent_class)->dispose (object); G_OBJECT_CLASS (ges_effect_parent_class)->dispose (object);
} }
static void static void
ges_track_parse_launch_effect_finalize (GObject * object) ges_effect_finalize (GObject * object)
{ {
GESTrackParseLaunchEffect *self = GES_TRACK_PARSE_LAUNCH_EFFECT (object); GESEffect *self = GES_EFFECT (object);
if (self->priv->bin_description) if (self->priv->bin_description)
g_free (self->priv->bin_description); g_free (self->priv->bin_description);
G_OBJECT_CLASS (ges_track_parse_launch_effect_parent_class)->finalize G_OBJECT_CLASS (ges_effect_parent_class)->finalize (object);
(object);
} }
static GstElement * static GstElement *
ges_track_parse_launch_effect_create_element (GESTrackElement * object) ges_effect_create_element (GESTrackElement * object)
{ {
GstElement *effect; GstElement *effect;
gchar *bin_desc; gchar *bin_desc;
GError *error = NULL; GError *error = NULL;
GESTrackParseLaunchEffect *self = GES_TRACK_PARSE_LAUNCH_EFFECT (object); GESEffect *self = GES_EFFECT (object);
GESTrack *track = ges_track_element_get_track (object); GESTrack *track = ges_track_element_get_track (object);
if (!track) { if (!track) {
@ -230,19 +225,19 @@ ges_track_parse_launch_effect_create_element (GESTrackElement * object)
} }
/** /**
* ges_track_parse_launch_effect_new: * ges_effect_new:
* @bin_description: The gst-launch like bin description of the effect * @bin_description: The gst-launch like bin description of the effect
* *
* Creates a new #GESTrackParseLaunchEffect from the description of the bin. * Creates a new #GESEffect from the description of the bin.
* *
* Returns: a newly created #GESTrackParseLaunchEffect, or %NULL if something went * Returns: a newly created #GESEffect, or %NULL if something went
* wrong. * wrong.
* *
* Since: 0.10.2 * Since: 0.10.2
*/ */
GESTrackParseLaunchEffect * GESEffect *
ges_track_parse_launch_effect_new (const gchar * bin_description) ges_effect_new (const gchar * bin_description)
{ {
return g_object_new (GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, "bin-description", return g_object_new (GES_TYPE_EFFECT, "bin-description",
bin_description, NULL); bin_description, NULL);
} }

82
ges/ges-effect.h Normal file
View file

@ -0,0 +1,82 @@
/* GStreamer Editing Services
* Copyright (C) 2010 Thibault Saunier <thibault.saunier@collabora.co.uk>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef _GES_EFFECT
#define _GES_EFFECT
#include <glib-object.h>
#include <ges/ges-types.h>
#include <ges/ges-base-effect.h>
G_BEGIN_DECLS
#define GES_TYPE_EFFECT ges_effect_get_type()
#define GES_EFFECT(obj) \
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GES_TYPE_EFFECT, GESEffect))
#define GES_EFFECT_CLASS(klass) \
(G_TYPE_CHECK_CLASS_CAST ((klass), GES_TYPE_EFFECT, GESEffectClass))
#define GES_IS_EFFECT(obj) \
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GES_TYPE_EFFECT))
#define GES_IS_EFFECT_CLASS(klass) \
(G_TYPE_CHECK_CLASS_TYPE ((klass), GES_TYPE_EFFECT))
#define GES_EFFECT_GET_CLASS(obj) \
(G_TYPE_INSTANCE_GET_CLASS ((obj), GES_TYPE_EFFECT, GESEffectClass))
typedef struct _GESEffectPrivate GESEffectPrivate;
/**
* GESEffect:
*
*/
struct _GESEffect
{
/*< private > */
GESBaseEffect parent;
GESEffectPrivate *priv;
/* Padding for API extension */
gpointer _ges_reserved[GES_PADDING];
};
/**
* GESEffectClass:
* @parent_class: parent class
*/
struct _GESEffectClass
{
/*< private > */
GESBaseEffectClass parent_class;
/* Padding for API extension */
gpointer _ges_reserved[GES_PADDING];
};
GType ges_effect_get_type (void);
GESEffect*
ges_effect_new (const gchar * bin_description);
G_END_DECLS
#endif /* _GES_EFFECT */

View file

@ -796,7 +796,7 @@ track_element_added_cb (GESClip * object,
continue; continue;
} }
if (GES_IS_TRACK_PARSE_LAUNCH_EFFECT (tmp->data)) { if (GES_IS_EFFECT (tmp->data)) {
has_effect = TRUE; has_effect = TRUE;
continue; continue;
} }
@ -829,7 +829,7 @@ track_element_added_cb (GESClip * object,
/* We set the effects start and duration */ /* We set the effects start and duration */
track = ges_track_element_get_track (tmp->data); track = ges_track_element_get_track (tmp->data);
if (GES_IS_TRACK_PARSE_LAUNCH_EFFECT (tmp->data) if (GES_IS_EFFECT (tmp->data)
&& (type == track->type)) { && (type == track->type)) {
/* We lock the track objects so we do not move the whole Clip */ /* We lock the track objects so we do not move the whole Clip */
ges_track_element_set_locked (tmp->data, FALSE); ges_track_element_set_locked (tmp->data, FALSE);
@ -929,10 +929,10 @@ make_source (GESFormatter * self, GList * reflist, GHashTable * source_table)
} }
} else { } else {
GESTrackParseLaunchEffect *effect; GESEffect *effect;
gchar *active = (gchar *) g_hash_table_lookup (props_table, "active"); gchar *active = (gchar *) g_hash_table_lookup (props_table, "active");
effect = ges_track_parse_launch_effect_new ((gchar *) effect = ges_effect_new ((gchar *)
g_hash_table_lookup (props_table, (gchar *) "effect_name")); g_hash_table_lookup (props_table, (gchar *) "effect_name"));
ges_track_element_set_track_type (GES_TRACK_ELEMENT (effect), ges_track_element_set_track_type (GES_TRACK_ELEMENT (effect),
(video ? GES_TRACK_TYPE_VIDEO : GES_TRACK_TYPE_AUDIO)); (video ? GES_TRACK_TYPE_VIDEO : GES_TRACK_TYPE_AUDIO));

View file

@ -1,82 +0,0 @@
/* GStreamer Editing Services
* Copyright (C) 2010 Thibault Saunier <thibault.saunier@collabora.co.uk>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef _GES_TRACK_PARSE_LAUNCH_EFFECT
#define _GES_TRACK_PARSE_LAUNCH_EFFECT
#include <glib-object.h>
#include <ges/ges-types.h>
#include <ges/ges-base-effect.h>
G_BEGIN_DECLS
#define GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT ges_track_parse_launch_effect_get_type()
#define GES_TRACK_PARSE_LAUNCH_EFFECT(obj) \
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, GESTrackParseLaunchEffect))
#define GES_TRACK_PARSE_LAUNCH_EFFECT_CLASS(klass) \
(G_TYPE_CHECK_CLASS_CAST ((klass), GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, GESTrackParseLaunchEffectClass))
#define GES_IS_TRACK_PARSE_LAUNCH_EFFECT(obj) \
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT))
#define GES_IS_TRACK_PARSE_LAUNCH_EFFECT_CLASS(klass) \
(G_TYPE_CHECK_CLASS_TYPE ((klass), GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT))
#define GES_TRACK_PARSE_LAUNCH_EFFECT_GET_CLASS(obj) \
(G_TYPE_INSTANCE_GET_CLASS ((obj), GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, GESTrackParseLaunchEffectClass))
typedef struct _GESTrackParseLaunchEffectPrivate GESTrackParseLaunchEffectPrivate;
/**
* GESTrackParseLaunchEffect:
*
*/
struct _GESTrackParseLaunchEffect
{
/*< private > */
GESBaseEffect parent;
GESTrackParseLaunchEffectPrivate *priv;
/* Padding for API extension */
gpointer _ges_reserved[GES_PADDING];
};
/**
* GESTrackParseLaunchEffectClass:
* @parent_class: parent class
*/
struct _GESTrackParseLaunchEffectClass
{
/*< private > */
GESBaseEffectClass parent_class;
/* Padding for API extension */
gpointer _ges_reserved[GES_PADDING];
};
GType ges_track_parse_launch_effect_get_type (void);
GESTrackParseLaunchEffect*
ges_track_parse_launch_effect_new (const gchar * bin_description);
G_END_DECLS
#endif /* _GES_TRACK_PARSE_LAUNCH_EFFECT */

View file

@ -98,8 +98,8 @@ typedef struct _GESTrackOperationClass GESTrackOperationClass;
typedef struct _GESBaseEffect GESBaseEffect; typedef struct _GESBaseEffect GESBaseEffect;
typedef struct _GESBaseEffectClass GESBaseEffectClass; typedef struct _GESBaseEffectClass GESBaseEffectClass;
typedef struct _GESTrackParseLaunchEffect GESTrackParseLaunchEffect; typedef struct _GESEffect GESEffect;
typedef struct _GESTrackParseLaunchEffectClass GESTrackParseLaunchEffectClass; typedef struct _GESEffectClass GESEffectClass;
typedef struct _GESTrackFileSource GESTrackFileSource; typedef struct _GESTrackFileSource GESTrackFileSource;
typedef struct _GESTrackFileSourceClass GESTrackFileSourceClass; typedef struct _GESTrackFileSourceClass GESTrackFileSourceClass;

View file

@ -82,7 +82,7 @@ ges_init (void)
GES_TYPE_XML_FORMATTER; GES_TYPE_XML_FORMATTER;
/* Register track objects */ /* Register track objects */
GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT; GES_TYPE_EFFECT;
/* Register interfaces */ /* Register interfaces */
GES_TYPE_META_CONTAINER; GES_TYPE_META_CONTAINER;

View file

@ -70,7 +70,7 @@
#include <ges/ges-track-video-transition.h> #include <ges/ges-track-video-transition.h>
#include <ges/ges-track-audio-transition.h> #include <ges/ges-track-audio-transition.h>
#include <ges/ges-base-effect.h> #include <ges/ges-base-effect.h>
#include <ges/ges-track-parse-launch-effect.h> #include <ges/ges-effect.h>
#include <ges/ges-formatter.h> #include <ges/ges-formatter.h>
#include <ges/ges-pitivi-formatter.h> #include <ges/ges-pitivi-formatter.h>
#include <ges/ges-utils.h> #include <ges/ges-utils.h>

View file

@ -119,34 +119,28 @@ GST_START_TEST (test_proxy_asset)
fail_unless (ges_init ()); fail_unless (ges_init ());
identity = ges_asset_request (GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, "identity", identity = ges_asset_request (GES_TYPE_EFFECT, "identity", NULL);
NULL);
fail_unless (identity != NULL); fail_unless (identity != NULL);
nothing = ges_asset_request (GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, "nothing", nothing = ges_asset_request (GES_TYPE_EFFECT, "nothing", NULL);
NULL);
fail_if (nothing); fail_if (nothing);
nothing = ges_asset_cache_lookup (GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, nothing = ges_asset_cache_lookup (GES_TYPE_EFFECT, "nothing");
"nothing");
fail_unless (nothing != NULL); fail_unless (nothing != NULL);
fail_unless (ges_asset_set_proxy (nothing, "identity")); fail_unless (ges_asset_set_proxy (nothing, "identity"));
nothing_at_all = ges_asset_request (GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, nothing_at_all = ges_asset_request (GES_TYPE_EFFECT, "nothing_at_all", NULL);
"nothing_at_all", NULL);
fail_if (nothing_at_all); fail_if (nothing_at_all);
nothing_at_all = ges_asset_cache_lookup (GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, nothing_at_all = ges_asset_cache_lookup (GES_TYPE_EFFECT, "nothing_at_all");
"nothing_at_all");
fail_unless (nothing_at_all != NULL); fail_unless (nothing_at_all != NULL);
/* Now we proxy nothing_at_all to nothing which is itself proxied to identity */ /* Now we proxy nothing_at_all to nothing which is itself proxied to identity */
fail_unless (ges_asset_set_proxy (nothing_at_all, "nothing")); fail_unless (ges_asset_set_proxy (nothing_at_all, "nothing"));
/* If we request nothing_at_all we should get the good proxied identity */ /* If we request nothing_at_all we should get the good proxied identity */
nothing_at_all = ges_asset_request (GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT, nothing_at_all = ges_asset_request (GES_TYPE_EFFECT, "nothing_at_all", NULL);
"nothing_at_all", NULL);
fail_unless (nothing_at_all == identity); fail_unless (nothing_at_all == identity);
gst_object_unref (identity); gst_object_unref (identity);

View file

@ -28,11 +28,11 @@ deep_prop_changed_cb (GESTrackElement * obj, GstElement * element,
GST_START_TEST (test_effect_basic) GST_START_TEST (test_effect_basic)
{ {
GESTrackParseLaunchEffect *effect; GESEffect *effect;
ges_init (); ges_init ();
effect = ges_track_parse_launch_effect_new ("agingtv"); effect = ges_effect_new ("agingtv");
fail_unless (effect != NULL); fail_unless (effect != NULL);
g_object_unref (effect); g_object_unref (effect);
} }
@ -44,7 +44,7 @@ GST_START_TEST (test_add_effect_to_clip)
GESTimeline *timeline; GESTimeline *timeline;
GESTimelineLayer *layer; GESTimelineLayer *layer;
GESTrack *track_audio, *track_video; GESTrack *track_audio, *track_video;
GESTrackParseLaunchEffect *base_effect; GESEffect *base_effect;
GESTestClip *source; GESTestClip *source;
ges_init (); ges_init ();
@ -67,7 +67,7 @@ GST_START_TEST (test_add_effect_to_clip)
GST_DEBUG ("Create effect"); GST_DEBUG ("Create effect");
base_effect = ges_track_parse_launch_effect_new ("agingtv"); base_effect = ges_effect_new ("agingtv");
fail_unless (GES_IS_BASE_EFFECT (base_effect)); fail_unless (GES_IS_BASE_EFFECT (base_effect));
@ -91,7 +91,7 @@ GST_START_TEST (test_get_effects_from_tl)
GESTimeline *timeline; GESTimeline *timeline;
GESTimelineLayer *layer; GESTimelineLayer *layer;
GESTrack *track_video; GESTrack *track_video;
GESTrackParseLaunchEffect *base_effect, *base_effect1, *base_effect2; GESEffect *base_effect, *base_effect1, *base_effect2;
GESTestClip *source; GESTestClip *source;
GList *effects, *tmp = NULL; GList *effects, *tmp = NULL;
gint effect_prio = -1; gint effect_prio = -1;
@ -115,9 +115,9 @@ GST_START_TEST (test_get_effects_from_tl)
GST_DEBUG ("Create effect"); GST_DEBUG ("Create effect");
base_effect = ges_track_parse_launch_effect_new ("agingtv"); base_effect = ges_effect_new ("agingtv");
base_effect1 = ges_track_parse_launch_effect_new ("agingtv"); base_effect1 = ges_effect_new ("agingtv");
base_effect2 = ges_track_parse_launch_effect_new ("agingtv"); base_effect2 = ges_effect_new ("agingtv");
fail_unless (GES_IS_BASE_EFFECT (base_effect)); fail_unless (GES_IS_BASE_EFFECT (base_effect));
fail_unless (GES_IS_BASE_EFFECT (base_effect1)); fail_unless (GES_IS_BASE_EFFECT (base_effect1));
@ -167,7 +167,7 @@ GST_START_TEST (test_effect_clip)
GESTimelineLayer *layer; GESTimelineLayer *layer;
GESTrack *track_audio, *track_video; GESTrack *track_audio, *track_video;
GESEffectClip *effect_clip; GESEffectClip *effect_clip;
GESTrackParseLaunchEffect *tck_effect, *tck_effect1; GESEffect *tck_effect, *tck_effect1;
GList *effects, *tmp; GList *effects, *tmp;
gint i, clip_height; gint i, clip_height;
gint effect_prio = -1; gint effect_prio = -1;
@ -196,7 +196,7 @@ GST_START_TEST (test_effect_clip)
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer), ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer),
(GESClip *) effect_clip, 0); (GESClip *) effect_clip, 0);
tck_effect = ges_track_parse_launch_effect_new ("identity"); tck_effect = ges_effect_new ("identity");
fail_unless (ges_clip_add_track_element (GES_CLIP fail_unless (ges_clip_add_track_element (GES_CLIP
(effect_clip), GES_TRACK_ELEMENT (tck_effect))); (effect_clip), GES_TRACK_ELEMENT (tck_effect)));
fail_unless (ges_track_add_object (track_video, fail_unless (ges_track_add_object (track_video,
@ -205,7 +205,7 @@ GST_START_TEST (test_effect_clip)
g_object_get (effect_clip, "height", &clip_height, NULL); g_object_get (effect_clip, "height", &clip_height, NULL);
assert_equals_int (clip_height, 3); assert_equals_int (clip_height, 3);
tck_effect1 = ges_track_parse_launch_effect_new ("identity"); tck_effect1 = ges_effect_new ("identity");
fail_unless (ges_clip_add_track_element (GES_CLIP fail_unless (ges_clip_add_track_element (GES_CLIP
(effect_clip), GES_TRACK_ELEMENT (tck_effect1))); (effect_clip), GES_TRACK_ELEMENT (tck_effect1)));
fail_unless (ges_track_add_object (track_audio, fail_unless (ges_track_add_object (track_audio,
@ -241,7 +241,7 @@ GST_START_TEST (test_priorities_clip)
GESTimelineLayer *layer; GESTimelineLayer *layer;
GESTrack *track_audio, *track_video; GESTrack *track_audio, *track_video;
GESEffectClip *effect_clip; GESEffectClip *effect_clip;
GESTrackParseLaunchEffect *tck_effect, *tck_effect1; GESEffect *tck_effect, *tck_effect1;
GList *effects, *tmp; GList *effects, *tmp;
gint i, clip_height; gint i, clip_height;
gint effect_prio = -1; gint effect_prio = -1;
@ -265,7 +265,7 @@ GST_START_TEST (test_priorities_clip)
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer), ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer),
(GESClip *) effect_clip, 0); (GESClip *) effect_clip, 0);
tck_effect = ges_track_parse_launch_effect_new ("identity"); tck_effect = ges_effect_new ("identity");
fail_unless (ges_clip_add_track_element (GES_CLIP fail_unless (ges_clip_add_track_element (GES_CLIP
(effect_clip), GES_TRACK_ELEMENT (tck_effect))); (effect_clip), GES_TRACK_ELEMENT (tck_effect)));
fail_unless (ges_track_add_object (track_video, fail_unless (ges_track_add_object (track_video,
@ -274,7 +274,7 @@ GST_START_TEST (test_priorities_clip)
g_object_get (effect_clip, "height", &clip_height, NULL); g_object_get (effect_clip, "height", &clip_height, NULL);
fail_unless (clip_height == 3); fail_unless (clip_height == 3);
tck_effect1 = ges_track_parse_launch_effect_new ("identity"); tck_effect1 = ges_effect_new ("identity");
fail_unless (ges_clip_add_track_element (GES_CLIP fail_unless (ges_clip_add_track_element (GES_CLIP
(effect_clip), GES_TRACK_ELEMENT (tck_effect1))); (effect_clip), GES_TRACK_ELEMENT (tck_effect1)));
fail_unless (ges_track_add_object (track_audio, fail_unless (ges_track_add_object (track_audio,
@ -341,8 +341,7 @@ GST_START_TEST (test_base_effect_set_properties)
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer), ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer),
(GESClip *) effect_clip, 0); (GESClip *) effect_clip, 0);
tck_effect = tck_effect = GES_TRACK_ELEMENT (ges_effect_new ("agingtv"));
GES_TRACK_ELEMENT (ges_track_parse_launch_effect_new ("agingtv"));
fail_unless (ges_clip_add_track_element (GES_CLIP (effect_clip), tck_effect)); fail_unless (ges_clip_add_track_element (GES_CLIP (effect_clip), tck_effect));
fail_unless (ges_track_add_object (track_video, tck_effect)); fail_unless (ges_track_add_object (track_video, tck_effect));
@ -406,7 +405,7 @@ GST_START_TEST (test_clip_signals)
GESTimelineLayer *layer; GESTimelineLayer *layer;
GESTrack *track_video; GESTrack *track_video;
GESEffectClip *effect_clip; GESEffectClip *effect_clip;
GESTrackParseLaunchEffect *tck_effect; GESEffect *tck_effect;
GValue val = { 0, }; GValue val = { 0, };
ges_init (); ges_init ();
@ -428,7 +427,7 @@ GST_START_TEST (test_clip_signals)
ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer), ges_simple_timeline_layer_add_object ((GESSimpleTimelineLayer *) (layer),
(GESClip *) effect_clip, 0); (GESClip *) effect_clip, 0);
tck_effect = ges_track_parse_launch_effect_new ("agingtv"); tck_effect = ges_effect_new ("agingtv");
fail_unless (ges_clip_add_track_element (GES_CLIP fail_unless (ges_clip_add_track_element (GES_CLIP
(effect_clip), GES_TRACK_ELEMENT (tck_effect))); (effect_clip), GES_TRACK_ELEMENT (tck_effect)));
fail_unless (ges_track_add_object (track_video, fail_unless (ges_track_add_object (track_video,

View file

@ -143,12 +143,12 @@ GST_START_TEST (test_project_unexistant_effect)
(GCallback) error_loading_asset_cb, mainloop); (GCallback) error_loading_asset_cb, mainloop);
fail_unless (ges_project_create_asset (project, "nowaythiselementexists", fail_unless (ges_project_create_asset (project, "nowaythiselementexists",
GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT)); GES_TYPE_EFFECT));
g_main_loop_run (mainloop); g_main_loop_run (mainloop);
/* And.... try again! */ /* And.... try again! */
fail_if (ges_project_create_asset (project, "nowaythiselementexists", fail_if (ges_project_create_asset (project, "nowaythiselementexists",
GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT)); GES_TYPE_EFFECT));
fail_if (added_cb_called); fail_if (added_cb_called);
fail_if (removed_cb_called); fail_if (removed_cb_called);
@ -169,8 +169,7 @@ asset_added_cb (GESProject * project, GESAsset * asset)
gchar *uri = ges_test_file_uri ("audio_video.ogg"); gchar *uri = ges_test_file_uri ("audio_video.ogg");
GstDiscovererInfo *info; GstDiscovererInfo *info;
if (ges_asset_get_extractable_type (asset) == if (ges_asset_get_extractable_type (asset) == GES_TYPE_EFFECT) {
GES_TYPE_TRACK_PARSE_LAUNCH_EFFECT) {
assert_equals_string (ges_asset_get_id (asset), "agingtv"); assert_equals_string (ges_asset_get_id (asset), "agingtv");
} else { } else {
info = ges_uri_clip_asset_get_info (GES_URI_CLIP_ASSET (asset)); info = ges_uri_clip_asset_get_info (GES_URI_CLIP_ASSET (asset));

View file

@ -15,7 +15,7 @@
<track track-type="4" caps="video/x-raw" track-id="1"/> <track track-type="4" caps="video/x-raw" track-id="1"/>
<layer priority="0" properties='properties, auto-transition=(boolean)true;' metadatas='metadatas, a=(guint)3'> <layer priority="0" properties='properties, auto-transition=(boolean)true;' metadatas='metadatas, a=(guint)3'>
<clip id="0" layer-priority='0' asset-id="file:///test/not/exisiting" type-name="GESUriClip" track-types="6" start="0" duration="1000000000"> <clip id="0" layer-priority='0' asset-id="file:///test/not/exisiting" type-name="GESUriClip" track-types="6" start="0" duration="1000000000">
<effect asset-id='agingtv' clip-id='0' type-name='GESTrackParseLaunchEffect' track-type='4' track-id='1' metadatas='metadatas;' children-properties='properties, scratch-lines=(uint)12;'/> <effect asset-id='agingtv' clip-id='0' type-name='GESEffect' track-type='4' track-id='1' metadatas='metadatas;' children-properties='properties, scratch-lines=(uint)12;'/>
</clip> </clip>
</layer> </layer>
<layer priority="1" properties='properties, auto-transition=(boolean)true;'> <layer priority="1" properties='properties, auto-transition=(boolean)true;'>

View file

@ -1078,7 +1078,7 @@ app_add_effect_on_selected_clips (App * app, const gchar * bin_desc,
objects = ges_timeline_layer_get_objects (app->layer); objects = ges_timeline_layer_get_objects (app->layer);
for (tmp = objects; tmp; tmp = tmp->next) { for (tmp = objects; tmp; tmp = tmp->next) {
effect = GES_TRACK_ELEMENT (ges_track_parse_launch_effect_new (bin_desc)); effect = GES_TRACK_ELEMENT (ges_effect_new (bin_desc));
ges_clip_add_track_element (GES_CLIP (tmp->data), effect); ges_clip_add_track_element (GES_CLIP (tmp->data), effect);
if (type == GES_TRACK_TYPE_VIDEO) if (type == GES_TRACK_TYPE_VIDEO)