stage: Use macros for subclassing boilerplate
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3387>
This commit is contained in:
parent
62482c2ac0
commit
d07056992b
@ -32,7 +32,6 @@
|
|||||||
G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterClone, g_object_unref)
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterClone, g_object_unref)
|
||||||
G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterInputDevice, g_object_unref)
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterInputDevice, g_object_unref)
|
||||||
G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterScrollActor, g_object_unref)
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterScrollActor, g_object_unref)
|
||||||
G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterStage, g_object_unref)
|
|
||||||
G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterText, g_object_unref)
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC (ClutterText, g_object_unref)
|
||||||
|
|
||||||
#endif /* __GI_SCANNER__ */
|
#endif /* __GI_SCANNER__ */
|
||||||
|
@ -105,7 +105,7 @@ typedef struct _PointerDeviceEntry
|
|||||||
GArray *event_emission_chain;
|
GArray *event_emission_chain;
|
||||||
} PointerDeviceEntry;
|
} PointerDeviceEntry;
|
||||||
|
|
||||||
struct _ClutterStagePrivate
|
typedef struct _ClutterStagePrivate
|
||||||
{
|
{
|
||||||
/* the stage implementation */
|
/* the stage implementation */
|
||||||
ClutterStageWindow *impl;
|
ClutterStageWindow *impl;
|
||||||
@ -136,7 +136,7 @@ struct _ClutterStagePrivate
|
|||||||
GHashTable *touch_sequences;
|
GHashTable *touch_sequences;
|
||||||
|
|
||||||
guint actor_needs_immediate_relayout : 1;
|
guint actor_needs_immediate_relayout : 1;
|
||||||
};
|
} ClutterStagePrivate;
|
||||||
|
|
||||||
struct _ClutterGrab
|
struct _ClutterGrab
|
||||||
{
|
{
|
||||||
@ -200,7 +200,8 @@ clutter_stage_get_preferred_width (ClutterActor *self,
|
|||||||
gfloat *min_width_p,
|
gfloat *min_width_p,
|
||||||
gfloat *natural_width_p)
|
gfloat *natural_width_p)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = CLUTTER_STAGE (self)->priv;
|
ClutterStagePrivate *priv =
|
||||||
|
clutter_stage_get_instance_private (CLUTTER_STAGE (self));
|
||||||
MtkRectangle geom;
|
MtkRectangle geom;
|
||||||
|
|
||||||
if (priv->impl == NULL)
|
if (priv->impl == NULL)
|
||||||
@ -221,7 +222,8 @@ clutter_stage_get_preferred_height (ClutterActor *self,
|
|||||||
gfloat *min_height_p,
|
gfloat *min_height_p,
|
||||||
gfloat *natural_height_p)
|
gfloat *natural_height_p)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = CLUTTER_STAGE (self)->priv;
|
ClutterStagePrivate *priv =
|
||||||
|
clutter_stage_get_instance_private (CLUTTER_STAGE (self));
|
||||||
MtkRectangle geom;
|
MtkRectangle geom;
|
||||||
|
|
||||||
if (priv->impl == NULL)
|
if (priv->impl == NULL)
|
||||||
@ -288,7 +290,8 @@ static void
|
|||||||
clutter_stage_allocate (ClutterActor *self,
|
clutter_stage_allocate (ClutterActor *self,
|
||||||
const ClutterActorBox *box)
|
const ClutterActorBox *box)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = CLUTTER_STAGE (self)->priv;
|
ClutterStagePrivate *priv =
|
||||||
|
clutter_stage_get_instance_private (CLUTTER_STAGE (self));
|
||||||
ClutterActorBox alloc = CLUTTER_ACTOR_BOX_INIT_ZERO;
|
ClutterActorBox alloc = CLUTTER_ACTOR_BOX_INIT_ZERO;
|
||||||
float new_width, new_height;
|
float new_width, new_height;
|
||||||
float width, height;
|
float width, height;
|
||||||
@ -339,7 +342,7 @@ setup_clip_frustum (ClutterStage *stage,
|
|||||||
const MtkRectangle *clip,
|
const MtkRectangle *clip,
|
||||||
graphene_frustum_t *frustum)
|
graphene_frustum_t *frustum)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
MtkRectangle geom;
|
MtkRectangle geom;
|
||||||
graphene_point3d_t camera_position;
|
graphene_point3d_t camera_position;
|
||||||
graphene_point3d_t p[4];
|
graphene_point3d_t p[4];
|
||||||
@ -472,7 +475,7 @@ clutter_stage_paint_view (ClutterStage *stage,
|
|||||||
const MtkRegion *redraw_clip,
|
const MtkRegion *redraw_clip,
|
||||||
ClutterFrame *frame)
|
ClutterFrame *frame)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
if (!priv->impl)
|
if (!priv->impl)
|
||||||
return;
|
return;
|
||||||
@ -523,7 +526,7 @@ clutter_stage_after_update (ClutterStage *stage,
|
|||||||
ClutterStageView *view,
|
ClutterStageView *view,
|
||||||
ClutterFrame *frame)
|
ClutterFrame *frame)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
g_signal_emit (stage, stage_signals[AFTER_UPDATE], 0, view, frame);
|
g_signal_emit (stage, stage_signals[AFTER_UPDATE], 0, view, frame);
|
||||||
|
|
||||||
@ -542,7 +545,8 @@ clutter_stage_get_paint_volume (ClutterActor *self,
|
|||||||
static void
|
static void
|
||||||
clutter_stage_realize (ClutterActor *self)
|
clutter_stage_realize (ClutterActor *self)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = CLUTTER_STAGE (self)->priv;
|
ClutterStagePrivate *priv =
|
||||||
|
clutter_stage_get_instance_private (CLUTTER_STAGE (self));
|
||||||
gboolean is_realized;
|
gboolean is_realized;
|
||||||
|
|
||||||
g_assert (priv->impl != NULL);
|
g_assert (priv->impl != NULL);
|
||||||
@ -555,7 +559,8 @@ clutter_stage_realize (ClutterActor *self)
|
|||||||
static void
|
static void
|
||||||
clutter_stage_unrealize (ClutterActor *self)
|
clutter_stage_unrealize (ClutterActor *self)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = CLUTTER_STAGE (self)->priv;
|
ClutterStagePrivate *priv =
|
||||||
|
clutter_stage_get_instance_private (CLUTTER_STAGE (self));
|
||||||
|
|
||||||
/* and then unrealize the implementation */
|
/* and then unrealize the implementation */
|
||||||
g_assert (priv->impl != NULL);
|
g_assert (priv->impl != NULL);
|
||||||
@ -567,7 +572,8 @@ clutter_stage_unrealize (ClutterActor *self)
|
|||||||
static void
|
static void
|
||||||
clutter_stage_show (ClutterActor *self)
|
clutter_stage_show (ClutterActor *self)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = CLUTTER_STAGE (self)->priv;
|
ClutterStagePrivate *priv =
|
||||||
|
clutter_stage_get_instance_private (CLUTTER_STAGE (self));
|
||||||
|
|
||||||
CLUTTER_ACTOR_CLASS (clutter_stage_parent_class)->show (self);
|
CLUTTER_ACTOR_CLASS (clutter_stage_parent_class)->show (self);
|
||||||
|
|
||||||
@ -598,7 +604,8 @@ clutter_stage_hide_all (ClutterActor *self)
|
|||||||
static void
|
static void
|
||||||
clutter_stage_hide (ClutterActor *self)
|
clutter_stage_hide (ClutterActor *self)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = CLUTTER_STAGE (self)->priv;
|
ClutterStagePrivate *priv =
|
||||||
|
clutter_stage_get_instance_private (CLUTTER_STAGE (self));
|
||||||
|
|
||||||
g_assert (priv->impl != NULL);
|
g_assert (priv->impl != NULL);
|
||||||
_clutter_stage_window_hide (priv->impl);
|
_clutter_stage_window_hide (priv->impl);
|
||||||
@ -610,7 +617,7 @@ static void
|
|||||||
clutter_stage_emit_key_focus_event (ClutterStage *stage,
|
clutter_stage_emit_key_focus_event (ClutterStage *stage,
|
||||||
gboolean focus_in)
|
gboolean focus_in)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
if (priv->key_focused_actor == NULL)
|
if (priv->key_focused_actor == NULL)
|
||||||
return;
|
return;
|
||||||
@ -641,7 +648,7 @@ _clutter_stage_queue_event (ClutterStage *stage,
|
|||||||
|
|
||||||
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
||||||
|
|
||||||
priv = stage->priv;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
g_queue_push_tail (priv->event_queue,
|
g_queue_push_tail (priv->event_queue,
|
||||||
copy_event ? clutter_event_copy (event) : event);
|
copy_event ? clutter_event_copy (event) : event);
|
||||||
@ -699,7 +706,7 @@ _clutter_stage_process_queued_events (ClutterStage *stage)
|
|||||||
|
|
||||||
COGL_TRACE_BEGIN_SCOPED (ProcessQueuedEvents, "Clutter::Stage::process_queued_events()");
|
COGL_TRACE_BEGIN_SCOPED (ProcessQueuedEvents, "Clutter::Stage::process_queued_events()");
|
||||||
|
|
||||||
priv = stage->priv;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
if (priv->event_queue->length == 0)
|
if (priv->event_queue->length == 0)
|
||||||
return;
|
return;
|
||||||
@ -710,7 +717,7 @@ _clutter_stage_process_queued_events (ClutterStage *stage)
|
|||||||
/* Steal events before starting processing to avoid reentrancy
|
/* Steal events before starting processing to avoid reentrancy
|
||||||
* issues */
|
* issues */
|
||||||
events = priv->event_queue->head;
|
events = priv->event_queue->head;
|
||||||
priv->event_queue->head = NULL;
|
priv->event_queue->head = NULL;
|
||||||
priv->event_queue->tail = NULL;
|
priv->event_queue->tail = NULL;
|
||||||
priv->event_queue->length = 0;
|
priv->event_queue->length = 0;
|
||||||
|
|
||||||
@ -801,7 +808,7 @@ void
|
|||||||
clutter_stage_queue_actor_relayout (ClutterStage *stage,
|
clutter_stage_queue_actor_relayout (ClutterStage *stage,
|
||||||
ClutterActor *actor)
|
ClutterActor *actor)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
clutter_stage_schedule_update (stage);
|
clutter_stage_schedule_update (stage);
|
||||||
|
|
||||||
@ -813,7 +820,7 @@ void
|
|||||||
clutter_stage_dequeue_actor_relayout (ClutterStage *stage,
|
clutter_stage_dequeue_actor_relayout (ClutterStage *stage,
|
||||||
ClutterActor *actor)
|
ClutterActor *actor)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
GSList *l;
|
GSList *l;
|
||||||
|
|
||||||
for (l = priv->pending_relayouts; l; l = l->next)
|
for (l = priv->pending_relayouts; l; l = l->next)
|
||||||
@ -848,7 +855,7 @@ void
|
|||||||
clutter_stage_maybe_relayout (ClutterActor *actor)
|
clutter_stage_maybe_relayout (ClutterActor *actor)
|
||||||
{
|
{
|
||||||
ClutterStage *stage = CLUTTER_STAGE (actor);
|
ClutterStage *stage = CLUTTER_STAGE (actor);
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
g_autoptr (GSList) stolen_list = NULL;
|
g_autoptr (GSList) stolen_list = NULL;
|
||||||
GSList *l;
|
GSList *l;
|
||||||
int count = 0;
|
int count = 0;
|
||||||
@ -898,7 +905,7 @@ GSList *
|
|||||||
clutter_stage_find_updated_devices (ClutterStage *stage,
|
clutter_stage_find_updated_devices (ClutterStage *stage,
|
||||||
ClutterStageView *view)
|
ClutterStageView *view)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
GSList *updating = NULL;
|
GSList *updating = NULL;
|
||||||
GHashTableIter iter;
|
GHashTableIter iter;
|
||||||
gpointer value;
|
gpointer value;
|
||||||
@ -927,7 +934,7 @@ void
|
|||||||
clutter_stage_finish_layout (ClutterStage *stage)
|
clutter_stage_finish_layout (ClutterStage *stage)
|
||||||
{
|
{
|
||||||
ClutterActor *actor = CLUTTER_ACTOR (stage);
|
ClutterActor *actor = CLUTTER_ACTOR (stage);
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
int phase;
|
int phase;
|
||||||
|
|
||||||
COGL_TRACE_BEGIN_SCOPED (ClutterStageUpdateActorStageViews,
|
COGL_TRACE_BEGIN_SCOPED (ClutterStageUpdateActorStageViews,
|
||||||
@ -961,7 +968,7 @@ void
|
|||||||
clutter_stage_update_devices (ClutterStage *stage,
|
clutter_stage_update_devices (ClutterStage *stage,
|
||||||
GSList *devices)
|
GSList *devices)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
GSList *l;
|
GSList *l;
|
||||||
|
|
||||||
COGL_TRACE_BEGIN_SCOPED (ClutterStageUpdateDevices, "Clutter::Stage::update_devices()");
|
COGL_TRACE_BEGIN_SCOPED (ClutterStageUpdateDevices, "Clutter::Stage::update_devices()");
|
||||||
@ -1020,7 +1027,7 @@ setup_ray_for_coordinates (ClutterStage *stage,
|
|||||||
graphene_point3d_t *point,
|
graphene_point3d_t *point,
|
||||||
graphene_ray_t *ray)
|
graphene_ray_t *ray)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
graphene_point3d_t camera_position;
|
graphene_point3d_t camera_position;
|
||||||
graphene_point3d_t p;
|
graphene_point3d_t p;
|
||||||
graphene_vec3_t direction;
|
graphene_vec3_t direction;
|
||||||
@ -1080,7 +1087,7 @@ clutter_stage_get_view_at (ClutterStage *stage,
|
|||||||
float x,
|
float x,
|
||||||
float y)
|
float y)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
GList *l;
|
GList *l;
|
||||||
|
|
||||||
for (l = _clutter_stage_window_get_views (priv->impl); l; l = l->next)
|
for (l = _clutter_stage_window_get_views (priv->impl); l; l = l->next)
|
||||||
@ -1107,11 +1114,11 @@ _clutter_stage_do_pick (ClutterStage *stage,
|
|||||||
MtkRegion **clear_area)
|
MtkRegion **clear_area)
|
||||||
{
|
{
|
||||||
ClutterActor *actor = CLUTTER_ACTOR (stage);
|
ClutterActor *actor = CLUTTER_ACTOR (stage);
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
float stage_width, stage_height;
|
float stage_width, stage_height;
|
||||||
ClutterStageView *view = NULL;
|
ClutterStageView *view = NULL;
|
||||||
|
|
||||||
priv = stage->priv;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
if (CLUTTER_ACTOR_IN_DESTRUCTION (stage))
|
if (CLUTTER_ACTOR_IN_DESTRUCTION (stage))
|
||||||
return actor;
|
return actor;
|
||||||
@ -1137,7 +1144,8 @@ static void
|
|||||||
clutter_stage_real_apply_transform (ClutterActor *stage,
|
clutter_stage_real_apply_transform (ClutterActor *stage,
|
||||||
graphene_matrix_t *matrix)
|
graphene_matrix_t *matrix)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = CLUTTER_STAGE (stage)->priv;
|
ClutterStagePrivate *priv =
|
||||||
|
clutter_stage_get_instance_private (CLUTTER_STAGE (stage));
|
||||||
|
|
||||||
/* FIXME: we probably shouldn't be explicitly resetting the matrix
|
/* FIXME: we probably shouldn't be explicitly resetting the matrix
|
||||||
* here... */
|
* here... */
|
||||||
@ -1188,7 +1196,8 @@ clutter_stage_get_property (GObject *gobject,
|
|||||||
GValue *value,
|
GValue *value,
|
||||||
GParamSpec *pspec)
|
GParamSpec *pspec)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = CLUTTER_STAGE (gobject)->priv;
|
ClutterStagePrivate *priv =
|
||||||
|
clutter_stage_get_instance_private (CLUTTER_STAGE (gobject));
|
||||||
|
|
||||||
switch (prop_id)
|
switch (prop_id)
|
||||||
{
|
{
|
||||||
@ -1218,7 +1227,7 @@ static void
|
|||||||
clutter_stage_dispose (GObject *object)
|
clutter_stage_dispose (GObject *object)
|
||||||
{
|
{
|
||||||
ClutterStage *stage = CLUTTER_STAGE (object);
|
ClutterStage *stage = CLUTTER_STAGE (object);
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
ClutterStageManager *stage_manager;
|
ClutterStageManager *stage_manager;
|
||||||
|
|
||||||
clutter_actor_hide (CLUTTER_ACTOR (object));
|
clutter_actor_hide (CLUTTER_ACTOR (object));
|
||||||
@ -1256,7 +1265,7 @@ static void
|
|||||||
clutter_stage_finalize (GObject *object)
|
clutter_stage_finalize (GObject *object)
|
||||||
{
|
{
|
||||||
ClutterStage *stage = CLUTTER_STAGE (object);
|
ClutterStage *stage = CLUTTER_STAGE (object);
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
g_queue_foreach (priv->event_queue, (GFunc) clutter_event_free, NULL);
|
g_queue_foreach (priv->event_queue, (GFunc) clutter_event_free, NULL);
|
||||||
g_queue_free (priv->event_queue);
|
g_queue_free (priv->event_queue);
|
||||||
@ -1629,7 +1638,7 @@ clutter_stage_init (ClutterStage *self)
|
|||||||
/* a stage is a top-level object */
|
/* a stage is a top-level object */
|
||||||
CLUTTER_SET_PRIVATE_FLAGS (self, CLUTTER_IS_TOPLEVEL);
|
CLUTTER_SET_PRIVATE_FLAGS (self, CLUTTER_IS_TOPLEVEL);
|
||||||
|
|
||||||
self->priv = priv = clutter_stage_get_instance_private (self);
|
priv = clutter_stage_get_instance_private (self);
|
||||||
|
|
||||||
CLUTTER_NOTE (BACKEND, "Creating stage from the default backend");
|
CLUTTER_NOTE (BACKEND, "Creating stage from the default backend");
|
||||||
backend = clutter_get_default_backend ();
|
backend = clutter_get_default_backend ();
|
||||||
@ -1683,7 +1692,7 @@ static void
|
|||||||
clutter_stage_set_perspective (ClutterStage *stage,
|
clutter_stage_set_perspective (ClutterStage *stage,
|
||||||
ClutterPerspective *perspective)
|
ClutterPerspective *perspective)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
if (priv->perspective.fovy == perspective->fovy &&
|
if (priv->perspective.fovy == perspective->fovy &&
|
||||||
priv->perspective.aspect == perspective->aspect &&
|
priv->perspective.aspect == perspective->aspect &&
|
||||||
@ -1717,10 +1726,13 @@ void
|
|||||||
clutter_stage_get_perspective (ClutterStage *stage,
|
clutter_stage_get_perspective (ClutterStage *stage,
|
||||||
ClutterPerspective *perspective)
|
ClutterPerspective *perspective)
|
||||||
{
|
{
|
||||||
|
ClutterStagePrivate *priv;
|
||||||
|
|
||||||
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
||||||
g_return_if_fail (perspective != NULL);
|
g_return_if_fail (perspective != NULL);
|
||||||
|
|
||||||
*perspective = stage->priv->perspective;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
*perspective = priv->perspective;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1737,10 +1749,13 @@ void
|
|||||||
_clutter_stage_get_projection_matrix (ClutterStage *stage,
|
_clutter_stage_get_projection_matrix (ClutterStage *stage,
|
||||||
graphene_matrix_t *projection)
|
graphene_matrix_t *projection)
|
||||||
{
|
{
|
||||||
|
ClutterStagePrivate *priv;
|
||||||
|
|
||||||
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
||||||
g_return_if_fail (projection != NULL);
|
g_return_if_fail (projection != NULL);
|
||||||
|
|
||||||
*projection = stage->priv->projection;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
*projection = priv->projection;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* This simply provides a simple mechanism for us to ensure that
|
/* This simply provides a simple mechanism for us to ensure that
|
||||||
@ -1755,7 +1770,7 @@ _clutter_stage_dirty_projection (ClutterStage *stage)
|
|||||||
|
|
||||||
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
||||||
|
|
||||||
priv = stage->priv;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
for (l = _clutter_stage_window_get_views (priv->impl); l; l = l->next)
|
for (l = _clutter_stage_window_get_views (priv->impl); l; l = l->next)
|
||||||
{
|
{
|
||||||
@ -1808,7 +1823,7 @@ clutter_stage_set_viewport (ClutterStage *stage,
|
|||||||
|
|
||||||
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
||||||
|
|
||||||
priv = stage->priv;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
x = 0.f;
|
x = 0.f;
|
||||||
y = 0.f;
|
y = 0.f;
|
||||||
@ -1844,7 +1859,7 @@ _clutter_stage_dirty_viewport (ClutterStage *stage)
|
|||||||
|
|
||||||
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
||||||
|
|
||||||
priv = stage->priv;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
for (l = _clutter_stage_window_get_views (priv->impl); l; l = l->next)
|
for (l = _clutter_stage_window_get_views (priv->impl); l; l = l->next)
|
||||||
{
|
{
|
||||||
@ -1882,7 +1897,7 @@ _clutter_stage_get_viewport (ClutterStage *stage,
|
|||||||
|
|
||||||
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
||||||
|
|
||||||
priv = stage->priv;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
*x = priv->viewport[0];
|
*x = priv->viewport[0];
|
||||||
*y = priv->viewport[1];
|
*y = priv->viewport[1];
|
||||||
@ -1933,7 +1948,7 @@ clutter_stage_read_pixels (ClutterStage *stage,
|
|||||||
|
|
||||||
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL);
|
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL);
|
||||||
|
|
||||||
priv = stage->priv;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
clutter_actor_get_allocation_box (CLUTTER_ACTOR (stage), &box);
|
clutter_actor_get_allocation_box (CLUTTER_ACTOR (stage), &box);
|
||||||
|
|
||||||
@ -2026,7 +2041,7 @@ clutter_stage_set_title (ClutterStage *stage,
|
|||||||
|
|
||||||
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
||||||
|
|
||||||
priv = stage->priv;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
g_free (priv->title);
|
g_free (priv->title);
|
||||||
priv->title = g_strdup (title);
|
priv->title = g_strdup (title);
|
||||||
@ -2051,9 +2066,12 @@ clutter_stage_set_title (ClutterStage *stage,
|
|||||||
const gchar *
|
const gchar *
|
||||||
clutter_stage_get_title (ClutterStage *stage)
|
clutter_stage_get_title (ClutterStage *stage)
|
||||||
{
|
{
|
||||||
|
ClutterStagePrivate *priv;
|
||||||
|
|
||||||
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL);
|
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL);
|
||||||
|
|
||||||
return stage->priv->title;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
return priv->title;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -2074,7 +2092,7 @@ clutter_stage_set_key_focus (ClutterStage *stage,
|
|||||||
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
||||||
g_return_if_fail (actor == NULL || CLUTTER_IS_ACTOR (actor));
|
g_return_if_fail (actor == NULL || CLUTTER_IS_ACTOR (actor));
|
||||||
|
|
||||||
priv = stage->priv;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
/* normalize the key focus. NULL == stage */
|
/* normalize the key focus. NULL == stage */
|
||||||
if (actor == CLUTTER_ACTOR (stage))
|
if (actor == CLUTTER_ACTOR (stage))
|
||||||
@ -2139,10 +2157,13 @@ clutter_stage_set_key_focus (ClutterStage *stage,
|
|||||||
ClutterActor *
|
ClutterActor *
|
||||||
clutter_stage_get_key_focus (ClutterStage *stage)
|
clutter_stage_get_key_focus (ClutterStage *stage)
|
||||||
{
|
{
|
||||||
|
ClutterStagePrivate *priv;
|
||||||
|
|
||||||
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL);
|
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL);
|
||||||
|
|
||||||
if (stage->priv->key_focused_actor)
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
return stage->priv->key_focused_actor;
|
if (priv->key_focused_actor)
|
||||||
|
return priv->key_focused_actor;
|
||||||
|
|
||||||
return CLUTTER_ACTOR (stage);
|
return CLUTTER_ACTOR (stage);
|
||||||
}
|
}
|
||||||
@ -2365,7 +2386,7 @@ view_2d_in_perspective (graphene_matrix_t *matrix,
|
|||||||
static void
|
static void
|
||||||
clutter_stage_update_view_perspective (ClutterStage *stage)
|
clutter_stage_update_view_perspective (ClutterStage *stage)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
ClutterPerspective perspective;
|
ClutterPerspective perspective;
|
||||||
float z_2d;
|
float z_2d;
|
||||||
|
|
||||||
@ -2401,7 +2422,7 @@ void
|
|||||||
_clutter_stage_maybe_setup_viewport (ClutterStage *stage,
|
_clutter_stage_maybe_setup_viewport (ClutterStage *stage,
|
||||||
ClutterStageView *view)
|
ClutterStageView *view)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
if (clutter_stage_view_is_dirty_viewport (view))
|
if (clutter_stage_view_is_dirty_viewport (view))
|
||||||
{
|
{
|
||||||
@ -2456,21 +2477,29 @@ void
|
|||||||
_clutter_stage_set_window (ClutterStage *stage,
|
_clutter_stage_set_window (ClutterStage *stage,
|
||||||
ClutterStageWindow *stage_window)
|
ClutterStageWindow *stage_window)
|
||||||
{
|
{
|
||||||
|
ClutterStagePrivate *priv;
|
||||||
|
|
||||||
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
g_return_if_fail (CLUTTER_IS_STAGE (stage));
|
||||||
g_return_if_fail (CLUTTER_IS_STAGE_WINDOW (stage_window));
|
g_return_if_fail (CLUTTER_IS_STAGE_WINDOW (stage_window));
|
||||||
|
|
||||||
if (stage->priv->impl != NULL)
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
g_object_unref (stage->priv->impl);
|
|
||||||
|
|
||||||
stage->priv->impl = stage_window;
|
if (priv->impl != NULL)
|
||||||
|
g_object_unref (priv->impl);
|
||||||
|
|
||||||
|
priv->impl = stage_window;
|
||||||
}
|
}
|
||||||
|
|
||||||
ClutterStageWindow *
|
ClutterStageWindow *
|
||||||
_clutter_stage_get_window (ClutterStage *stage)
|
_clutter_stage_get_window (ClutterStage *stage)
|
||||||
{
|
{
|
||||||
|
ClutterStagePrivate *priv;
|
||||||
|
|
||||||
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL);
|
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL);
|
||||||
|
|
||||||
return CLUTTER_STAGE_WINDOW (stage->priv->impl);
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
|
return CLUTTER_STAGE_WINDOW (priv->impl);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -2482,7 +2511,7 @@ _clutter_stage_get_window (ClutterStage *stage)
|
|||||||
void
|
void
|
||||||
clutter_stage_schedule_update (ClutterStage *stage)
|
clutter_stage_schedule_update (ClutterStage *stage)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
ClutterStageWindow *stage_window;
|
ClutterStageWindow *stage_window;
|
||||||
gboolean first_event;
|
gboolean first_event;
|
||||||
GList *l;
|
GList *l;
|
||||||
@ -2660,7 +2689,7 @@ clutter_stage_paint_to_framebuffer (ClutterStage *stage,
|
|||||||
float scale,
|
float scale,
|
||||||
ClutterPaintFlag paint_flags)
|
ClutterPaintFlag paint_flags)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
ClutterPaintContext *paint_context;
|
ClutterPaintContext *paint_context;
|
||||||
g_autoptr (MtkRegion) redraw_clip = NULL;
|
g_autoptr (MtkRegion) redraw_clip = NULL;
|
||||||
|
|
||||||
@ -2876,7 +2905,7 @@ clutter_stage_capture_view_into (ClutterStage *stage,
|
|||||||
GList *
|
GList *
|
||||||
clutter_stage_peek_stage_views (ClutterStage *stage)
|
clutter_stage_peek_stage_views (ClutterStage *stage)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
return _clutter_stage_window_get_views (priv->impl);
|
return _clutter_stage_window_get_views (priv->impl);
|
||||||
}
|
}
|
||||||
@ -2891,7 +2920,7 @@ GList *
|
|||||||
clutter_stage_get_views_for_rect (ClutterStage *stage,
|
clutter_stage_get_views_for_rect (ClutterStage *stage,
|
||||||
const graphene_rect_t *rect)
|
const graphene_rect_t *rect)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
GList *views_for_rect = NULL;
|
GList *views_for_rect = NULL;
|
||||||
GList *l;
|
GList *l;
|
||||||
|
|
||||||
@ -2914,7 +2943,7 @@ clutter_stage_get_views_for_rect (ClutterStage *stage,
|
|||||||
void
|
void
|
||||||
clutter_stage_set_actor_needs_immediate_relayout (ClutterStage *stage)
|
clutter_stage_set_actor_needs_immediate_relayout (ClutterStage *stage)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
priv->actor_needs_immediate_relayout = TRUE;
|
priv->actor_needs_immediate_relayout = TRUE;
|
||||||
}
|
}
|
||||||
@ -2923,7 +2952,7 @@ void
|
|||||||
clutter_stage_maybe_invalidate_focus (ClutterStage *self,
|
clutter_stage_maybe_invalidate_focus (ClutterStage *self,
|
||||||
ClutterActor *actor)
|
ClutterActor *actor)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = self->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (self);
|
||||||
GHashTableIter iter;
|
GHashTableIter iter;
|
||||||
gpointer value;
|
gpointer value;
|
||||||
|
|
||||||
@ -3004,7 +3033,7 @@ clutter_stage_update_device_entry (ClutterStage *self,
|
|||||||
ClutterActor *actor,
|
ClutterActor *actor,
|
||||||
MtkRegion *clear_area)
|
MtkRegion *clear_area)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = self->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (self);
|
||||||
PointerDeviceEntry *entry = NULL;
|
PointerDeviceEntry *entry = NULL;
|
||||||
|
|
||||||
g_assert (device != NULL);
|
g_assert (device != NULL);
|
||||||
@ -3057,7 +3086,7 @@ clutter_stage_remove_device_entry (ClutterStage *self,
|
|||||||
ClutterInputDevice *device,
|
ClutterInputDevice *device,
|
||||||
ClutterEventSequence *sequence)
|
ClutterEventSequence *sequence)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = self->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (self);
|
||||||
gboolean removed;
|
gboolean removed;
|
||||||
|
|
||||||
g_assert (device != NULL);
|
g_assert (device != NULL);
|
||||||
@ -3086,7 +3115,7 @@ clutter_stage_get_device_actor (ClutterStage *stage,
|
|||||||
ClutterInputDevice *device,
|
ClutterInputDevice *device,
|
||||||
ClutterEventSequence *sequence)
|
ClutterEventSequence *sequence)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
PointerDeviceEntry *entry = NULL;
|
PointerDeviceEntry *entry = NULL;
|
||||||
|
|
||||||
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL);
|
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), NULL);
|
||||||
@ -3112,7 +3141,7 @@ clutter_stage_get_device_coords (ClutterStage *stage,
|
|||||||
ClutterEventSequence *sequence,
|
ClutterEventSequence *sequence,
|
||||||
graphene_point_t *coords)
|
graphene_point_t *coords)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
PointerDeviceEntry *entry = NULL;
|
PointerDeviceEntry *entry = NULL;
|
||||||
|
|
||||||
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), FALSE);
|
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), FALSE);
|
||||||
@ -3138,7 +3167,7 @@ clutter_stage_set_device_coords (ClutterStage *stage,
|
|||||||
ClutterEventSequence *sequence,
|
ClutterEventSequence *sequence,
|
||||||
graphene_point_t coords)
|
graphene_point_t coords)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
PointerDeviceEntry *entry = NULL;
|
PointerDeviceEntry *entry = NULL;
|
||||||
|
|
||||||
if (sequence != NULL)
|
if (sequence != NULL)
|
||||||
@ -3201,7 +3230,7 @@ create_event_emission_chain (ClutterStage *stage,
|
|||||||
ClutterActor *topmost,
|
ClutterActor *topmost,
|
||||||
ClutterActor *deepmost)
|
ClutterActor *deepmost)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
g_assert (priv->cur_event_actors->len == 0);
|
g_assert (priv->cur_event_actors->len == 0);
|
||||||
@ -3283,7 +3312,7 @@ clutter_stage_emit_crossing_event (ClutterStage *self,
|
|||||||
ClutterActor *deepmost,
|
ClutterActor *deepmost,
|
||||||
ClutterActor *topmost)
|
ClutterActor *topmost)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = self->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (self);
|
||||||
ClutterInputDevice *device = clutter_event_get_device (event);
|
ClutterInputDevice *device = clutter_event_get_device (event);
|
||||||
ClutterEventSequence *sequence = clutter_event_get_event_sequence (event);
|
ClutterEventSequence *sequence = clutter_event_get_event_sequence (event);
|
||||||
PointerDeviceEntry *entry;
|
PointerDeviceEntry *entry;
|
||||||
@ -3510,7 +3539,7 @@ clutter_stage_check_in_clear_area (ClutterStage *stage,
|
|||||||
ClutterEventSequence *sequence,
|
ClutterEventSequence *sequence,
|
||||||
graphene_point_t point)
|
graphene_point_t point)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
PointerDeviceEntry *entry = NULL;
|
PointerDeviceEntry *entry = NULL;
|
||||||
|
|
||||||
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), FALSE);
|
g_return_val_if_fail (CLUTTER_IS_STAGE (stage), FALSE);
|
||||||
@ -3599,7 +3628,7 @@ clutter_stage_notify_grab_on_pointer_entry (ClutterStage *stage,
|
|||||||
unsigned int implicit_grab_n_removed = 0, implicit_grab_n_remaining = 0;
|
unsigned int implicit_grab_n_removed = 0, implicit_grab_n_remaining = 0;
|
||||||
ClutterEventType event_type = CLUTTER_NOTHING;
|
ClutterEventType event_type = CLUTTER_NOTHING;
|
||||||
ClutterActor *topmost, *deepmost;
|
ClutterActor *topmost, *deepmost;
|
||||||
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
if (!entry->current_actor)
|
if (!entry->current_actor)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -3665,7 +3694,7 @@ clutter_stage_notify_grab_on_pointer_entry (ClutterStage *stage,
|
|||||||
"[grab=%p device=%p sequence=%p implicit_grab_cancelled=%d] "
|
"[grab=%p device=%p sequence=%p implicit_grab_cancelled=%d] "
|
||||||
"Cancelled %u actors and actions (%u remaining) on implicit "
|
"Cancelled %u actors and actions (%u remaining) on implicit "
|
||||||
"grab due to new seat grab",
|
"grab due to new seat grab",
|
||||||
stage->priv->topmost_grab, device, sequence, implicit_grab_cancelled,
|
priv->topmost_grab, device, sequence, implicit_grab_cancelled,
|
||||||
implicit_grab_n_removed, implicit_grab_n_remaining);
|
implicit_grab_n_removed, implicit_grab_n_remaining);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3767,12 +3796,12 @@ clutter_stage_notify_grab_on_key_focus (ClutterStage *stage,
|
|||||||
ClutterActor *grab_actor,
|
ClutterActor *grab_actor,
|
||||||
ClutterActor *old_grab_actor)
|
ClutterActor *old_grab_actor)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
ClutterActor *key_focus;
|
ClutterActor *key_focus;
|
||||||
gboolean focus_in_grab, focus_in_old_grab;
|
gboolean focus_in_grab, focus_in_old_grab;
|
||||||
|
|
||||||
key_focus = priv->key_focused_actor ?
|
key_focus = priv->key_focused_actor ?
|
||||||
priv->key_focused_actor : CLUTTER_ACTOR (stage);
|
priv->key_focused_actor : CLUTTER_ACTOR (stage);
|
||||||
|
|
||||||
focus_in_grab =
|
focus_in_grab =
|
||||||
!grab_actor ||
|
!grab_actor ||
|
||||||
@ -3794,7 +3823,7 @@ clutter_stage_notify_grab (ClutterStage *stage,
|
|||||||
ClutterGrab *cur,
|
ClutterGrab *cur,
|
||||||
ClutterGrab *old)
|
ClutterGrab *old)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
ClutterActor *cur_actor = NULL, *old_actor = NULL;
|
ClutterActor *cur_actor = NULL, *old_actor = NULL;
|
||||||
PointerDeviceEntry *entry;
|
PointerDeviceEntry *entry;
|
||||||
GHashTableIter iter;
|
GHashTableIter iter;
|
||||||
@ -3884,7 +3913,7 @@ clutter_stage_grab_full (ClutterStage *stage,
|
|||||||
(ClutterStage *) _clutter_actor_get_stage_internal (actor),
|
(ClutterStage *) _clutter_actor_get_stage_internal (actor),
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
priv = stage->priv;
|
priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
if (!priv->topmost_grab)
|
if (!priv->topmost_grab)
|
||||||
{
|
{
|
||||||
@ -3973,7 +4002,7 @@ void
|
|||||||
clutter_stage_unlink_grab (ClutterStage *stage,
|
clutter_stage_unlink_grab (ClutterStage *stage,
|
||||||
ClutterGrab *grab)
|
ClutterGrab *grab)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
ClutterGrab *prev, *next;
|
ClutterGrab *prev, *next;
|
||||||
gboolean was_grabbed;
|
gboolean was_grabbed;
|
||||||
|
|
||||||
@ -4064,9 +4093,12 @@ clutter_grab_dismiss (ClutterGrab *grab)
|
|||||||
ClutterGrabState
|
ClutterGrabState
|
||||||
clutter_grab_get_seat_state (ClutterGrab *grab)
|
clutter_grab_get_seat_state (ClutterGrab *grab)
|
||||||
{
|
{
|
||||||
|
ClutterStagePrivate *priv;
|
||||||
|
|
||||||
g_return_val_if_fail (grab != NULL, CLUTTER_GRAB_STATE_NONE);
|
g_return_val_if_fail (grab != NULL, CLUTTER_GRAB_STATE_NONE);
|
||||||
|
|
||||||
return grab->stage->priv->grab_state;
|
priv = clutter_stage_get_instance_private (grab->stage);
|
||||||
|
return priv->grab_state;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -4080,7 +4112,7 @@ clutter_grab_get_seat_state (ClutterGrab *grab)
|
|||||||
ClutterActor *
|
ClutterActor *
|
||||||
clutter_stage_get_grab_actor (ClutterStage *stage)
|
clutter_stage_get_grab_actor (ClutterStage *stage)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = stage->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (stage);
|
||||||
|
|
||||||
if (!priv->topmost_grab)
|
if (!priv->topmost_grab)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -4250,7 +4282,7 @@ clutter_stage_maybe_lost_implicit_grab (ClutterStage *self,
|
|||||||
ClutterInputDevice *device,
|
ClutterInputDevice *device,
|
||||||
ClutterEventSequence *sequence)
|
ClutterEventSequence *sequence)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = self->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (self);
|
||||||
PointerDeviceEntry *entry = NULL;
|
PointerDeviceEntry *entry = NULL;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
@ -4286,7 +4318,7 @@ void
|
|||||||
clutter_stage_emit_event (ClutterStage *self,
|
clutter_stage_emit_event (ClutterStage *self,
|
||||||
const ClutterEvent *event)
|
const ClutterEvent *event)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = self->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (self);
|
||||||
ClutterInputDevice *device = clutter_event_get_device (event);
|
ClutterInputDevice *device = clutter_event_get_device (event);
|
||||||
ClutterEventSequence *sequence = clutter_event_get_event_sequence (event);
|
ClutterEventSequence *sequence = clutter_event_get_event_sequence (event);
|
||||||
PointerDeviceEntry *entry;
|
PointerDeviceEntry *entry;
|
||||||
@ -4461,7 +4493,7 @@ void
|
|||||||
clutter_stage_implicit_grab_actor_unmapped (ClutterStage *self,
|
clutter_stage_implicit_grab_actor_unmapped (ClutterStage *self,
|
||||||
ClutterActor *actor)
|
ClutterActor *actor)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = self->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (self);
|
||||||
GHashTableIter iter;
|
GHashTableIter iter;
|
||||||
PointerDeviceEntry *entry;
|
PointerDeviceEntry *entry;
|
||||||
|
|
||||||
@ -4485,7 +4517,7 @@ clutter_stage_notify_action_implicit_grab (ClutterStage *self,
|
|||||||
ClutterInputDevice *device,
|
ClutterInputDevice *device,
|
||||||
ClutterEventSequence *sequence)
|
ClutterEventSequence *sequence)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = self->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (self);
|
||||||
PointerDeviceEntry *entry;
|
PointerDeviceEntry *entry;
|
||||||
|
|
||||||
if (sequence != NULL)
|
if (sequence != NULL)
|
||||||
@ -4513,7 +4545,7 @@ clutter_stage_pointing_input_foreach (ClutterStage *self,
|
|||||||
ClutterStageInputForeachFunc func,
|
ClutterStageInputForeachFunc func,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
ClutterStagePrivate *priv = self->priv;
|
ClutterStagePrivate *priv = clutter_stage_get_instance_private (self);
|
||||||
GHashTableIter iter;
|
GHashTableIter iter;
|
||||||
PointerDeviceEntry *entry;
|
PointerDeviceEntry *entry;
|
||||||
|
|
||||||
|
@ -35,24 +35,14 @@
|
|||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
#define CLUTTER_TYPE_STAGE (clutter_stage_get_type())
|
#define CLUTTER_TYPE_STAGE (clutter_stage_get_type ())
|
||||||
|
|
||||||
#define CLUTTER_STAGE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), CLUTTER_TYPE_STAGE, ClutterStage))
|
CLUTTER_EXPORT
|
||||||
#define CLUTTER_STAGE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), CLUTTER_TYPE_STAGE, ClutterStageClass))
|
G_DECLARE_DERIVABLE_TYPE (ClutterStage,
|
||||||
#define CLUTTER_IS_STAGE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), CLUTTER_TYPE_STAGE))
|
clutter_stage,
|
||||||
#define CLUTTER_IS_STAGE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), CLUTTER_TYPE_STAGE))
|
CLUTTER,
|
||||||
#define CLUTTER_STAGE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), CLUTTER_TYPE_STAGE, ClutterStageClass))
|
STAGE,
|
||||||
|
ClutterActor)
|
||||||
typedef struct _ClutterStageClass ClutterStageClass;
|
|
||||||
typedef struct _ClutterStagePrivate ClutterStagePrivate;
|
|
||||||
|
|
||||||
struct _ClutterStage
|
|
||||||
{
|
|
||||||
/*< private >*/
|
|
||||||
ClutterActor parent_instance;
|
|
||||||
|
|
||||||
ClutterStagePrivate *priv;
|
|
||||||
};
|
|
||||||
/**
|
/**
|
||||||
* ClutterStageClass:
|
* ClutterStageClass:
|
||||||
* @activate: handler for the #ClutterStage::activate signal
|
* @activate: handler for the #ClutterStage::activate signal
|
||||||
@ -143,8 +133,6 @@ struct _ClutterFrameInfo
|
|||||||
|
|
||||||
CLUTTER_EXPORT
|
CLUTTER_EXPORT
|
||||||
GType clutter_perspective_get_type (void) G_GNUC_CONST;
|
GType clutter_perspective_get_type (void) G_GNUC_CONST;
|
||||||
CLUTTER_EXPORT
|
|
||||||
GType clutter_stage_get_type (void) G_GNUC_CONST;
|
|
||||||
|
|
||||||
CLUTTER_EXPORT
|
CLUTTER_EXPORT
|
||||||
void clutter_stage_get_perspective (ClutterStage *stage,
|
void clutter_stage_get_perspective (ClutterStage *stage,
|
||||||
|
Loading…
Reference in New Issue
Block a user