[vala/wip/issue/795] clutter-1.0: Bind Margin, PaintVolume, Point, Rect and Size as struct
- From: Rico Tzschichholz <ricotz src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [vala/wip/issue/795] clutter-1.0: Bind Margin, PaintVolume, Point, Rect and Size as struct
- Date: Wed, 8 May 2019 10:11:52 +0000 (UTC)
commit d51a165888939d250d34fc5b33c59be17e12dbf4
Author: Rico Tzschichholz <ricotz ubuntu com>
Date: Wed May 8 10:22:54 2019 +0200
clutter-1.0: Bind Margin, PaintVolume, Point, Rect and Size as struct
Reverts 0cd8009728245300d32009fb029898b4a3ceed8a and its confusion
regards "caller-allocates" out-parameters
Fixes https://gitlab.gnome.org/GNOME/vala/issues/795
vapi/clutter-1.0.vapi | 231 +++++++++++++++++-----------------
vapi/metadata/Clutter-1.0-custom.vala | 6 +-
vapi/metadata/Clutter-1.0.metadata | 37 +++---
3 files changed, 135 insertions(+), 139 deletions(-)
---
diff --git a/vapi/clutter-1.0.vapi b/vapi/clutter-1.0.vapi
index 5ce8990be..7ec2f2dd9 100644
--- a/vapi/clutter-1.0.vapi
+++ b/vapi/clutter-1.0.vapi
@@ -4788,7 +4788,7 @@ namespace Clutter {
[Version (since = "1.10")]
public void get_content_scaling_filters (out Clutter.ScalingFilter min_filter, out
Clutter.ScalingFilter mag_filter);
[Version (since = "1.10")]
- public unowned Clutter.PaintVolume get_default_paint_volume ();
+ public unowned Clutter.PaintVolume? get_default_paint_volume ();
[Version (deprecated = true, deprecated_since = "1.12")]
public float get_depth ();
[Version (since = "1.10")]
@@ -4820,7 +4820,7 @@ namespace Clutter {
[Version (since = "1.10")]
public unowned Clutter.LayoutManager get_layout_manager ();
[Version (since = "1.10")]
- public void get_margin (Clutter.Margin margin);
+ public Clutter.Margin get_margin ();
[Version (since = "1.10")]
public float get_margin_bottom ();
[Version (since = "1.10")]
@@ -4843,8 +4843,11 @@ namespace Clutter {
public uint8 get_paint_opacity ();
[Version (since = "0.8")]
public bool get_paint_visibility ();
+ [Version (since = "1.6")]
+ public unowned Clutter.PaintVolume? get_paint_volume ();
+ [CCode (vfunc_name = "get_paint_volume")]
[NoWrapper]
- public virtual bool get_paint_volume (Clutter.PaintVolume volume);
+ public virtual bool get_paint_volume_vfunc (out Clutter.PaintVolume volume);
[Version (since = "1.0")]
public unowned Pango.Context get_pango_context ();
public unowned Clutter.Actor? get_parent ();
@@ -4891,7 +4894,7 @@ namespace Clutter {
[Version (deprecated = true, deprecated_since = "1.12", since = "1.0")]
public Clutter.Matrix get_transformation_matrix ();
[Version (since = "1.6")]
- public unowned Clutter.PaintVolume get_transformed_paint_volume (Clutter.Actor
relative_to_ancestor);
+ public unowned Clutter.PaintVolume? get_transformed_paint_volume (Clutter.Actor
relative_to_ancestor);
[Version (since = "0.8")]
public void get_transformed_position (out float x, out float y);
[Version (since = "0.8")]
@@ -5162,7 +5165,7 @@ namespace Clutter {
public Clutter.Geometry clip { get; set; }
[NoAccessorMethod]
[Version (since = "1.12")]
- public Clutter.Rect clip_rect { owned get; set; }
+ public Clutter.Rect clip_rect { get; set; }
[Version (since = "1.0")]
public bool clip_to_allocation { get; set; }
[NoAccessorMethod]
@@ -5247,12 +5250,12 @@ namespace Clutter {
public uint opacity { get; set; }
[NoAccessorMethod]
[Version (since = "1.12")]
- public Clutter.Point pivot_point { owned get; set; }
+ public Clutter.Point pivot_point { get; set; }
[Version (since = "1.12")]
public float pivot_point_z { get; set; }
[NoAccessorMethod]
[Version (since = "1.12")]
- public Clutter.Point position { owned get; set; }
+ public Clutter.Point position { get; set; }
[Version (since = "0.6")]
public bool reactive { get; set; }
[NoAccessorMethod]
@@ -5303,7 +5306,7 @@ namespace Clutter {
public bool show_on_set_parent { get; set; }
[NoAccessorMethod]
[Version (since = "1.12")]
- public Clutter.Size size { owned get; set; }
+ public Clutter.Size size { get; set; }
[Version (since = "1.0")]
public Clutter.TextDirection text_direction { get; set; }
[Version (since = "1.12")]
@@ -6123,7 +6126,7 @@ namespace Clutter {
public class DragAction : Clutter.Action {
[CCode (has_construct_function = false, type = "ClutterAction*")]
public DragAction ();
- public bool get_drag_area (Clutter.Rect drag_area);
+ public bool get_drag_area (out Clutter.Rect drag_area);
public Clutter.DragAxis get_drag_axis ();
public unowned Clutter.Actor get_drag_handle ();
public void get_drag_threshold (out uint x_threshold, out uint y_threshold);
@@ -6135,7 +6138,7 @@ namespace Clutter {
public void set_drag_threshold (int x_threshold, int y_threshold);
[NoAccessorMethod]
[Version (since = "1.12")]
- public Clutter.Rect drag_area { owned get; set; }
+ public Clutter.Rect drag_area { get; set; }
[NoAccessorMethod]
[Version (since = "1.12")]
public bool drag_area_set { get; }
@@ -6169,7 +6172,7 @@ namespace Clutter {
[CCode (has_construct_function = false)]
protected Effect ();
[NoWrapper]
- public virtual bool get_paint_volume (Clutter.PaintVolume volume);
+ public virtual bool get_paint_volume (out Clutter.PaintVolume volume);
[NoWrapper]
public virtual void paint (Clutter.EffectPaintFlags flags);
[NoWrapper]
@@ -6230,7 +6233,7 @@ namespace Clutter {
public uint get_key_symbol ();
public unichar get_key_unicode ();
[Version (since = "1.12")]
- public void get_position (Clutter.Point position);
+ public Clutter.Point get_position ();
[Version (since = "1.0")]
public unowned Clutter.Actor get_related ();
[Version (since = "1.10")]
@@ -6469,7 +6472,7 @@ namespace Clutter {
[Version (since = "1.6")]
public bool get_axis_value ([CCode (array_length = false)] double[] axes, Clutter.InputAxis
axis, out double value);
[Version (since = "1.12")]
- public bool get_coords (Clutter.EventSequence? sequence, Clutter.Point point);
+ public bool get_coords (Clutter.EventSequence? sequence, out Clutter.Point point);
[Version (deprecated = true, deprecated_since = "1.12", since = "1.2")]
public void get_device_coords (out int x, out int y);
[Version (since = "1.0")]
@@ -6662,19 +6665,6 @@ namespace Clutter {
[CCode (cname = "clutter_list_model_newv", has_construct_function = false, type =
"ClutterModel*")]
public ListModel.newv ([CCode (array_length_cname = "n_columns", array_length_pos = 0.5,
array_length_type = "guint")] GLib.Type[] types, [CCode (array_length_cname = "n_columns", array_length_pos =
0.5, array_length_type = "guint")] string[] names);
}
- [CCode (cheader_filename = "clutter/clutter.h", copy_function = "g_boxed_copy", free_function =
"g_boxed_free", type_id = "clutter_margin_get_type ()")]
- [Compact]
- [Version (since = "1.10")]
- public class Margin {
- public float bottom;
- public float left;
- public float right;
- public float top;
- [CCode (has_construct_function = false)]
- public Margin ();
- public Clutter.Margin copy ();
- public void free ();
- }
[CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_model_get_type ()")]
[Version (deprecated = true, deprecated_since = "1.24", since = "0.6")]
public abstract class Model : GLib.Object, Clutter.Scriptable {
@@ -6764,7 +6754,7 @@ namespace Clutter {
public virtual Cogl.Handle create_texture (float width, float height);
public unowned Cogl.Material get_target ();
[Version (since = "1.14")]
- public bool get_target_rect (out unowned Clutter.Rect rect);
+ public bool get_target_rect (out Clutter.Rect rect);
[Version (deprecated = true, deprecated_since = "1.14", since = "1.8")]
public bool get_target_size (out float width, out float height);
[Version (since = "1.10")]
@@ -6798,37 +6788,6 @@ namespace Clutter {
public void set_name (string name);
public void unref ();
}
- [CCode (cheader_filename = "clutter/clutter.h", copy_function = "g_boxed_copy", free_function =
"g_boxed_free", type_id = "clutter_paint_volume_get_type ()")]
- [Compact]
- [Version (since = "1.4")]
- public class PaintVolume {
- [Version (since = "1.6")]
- public Clutter.PaintVolume copy ();
- [Version (since = "1.6")]
- public void free ();
- [Version (since = "1.6")]
- public float get_depth ();
- [Version (since = "1.6")]
- public float get_height ();
- [Version (since = "1.6")]
- public Clutter.Vertex get_origin ();
- [Version (since = "1.6")]
- public float get_width ();
- [Version (since = "1.6")]
- public void set_depth (float depth);
- [Version (since = "1.6")]
- public bool set_from_allocation (Clutter.Actor actor);
- [Version (since = "1.6")]
- public void set_height (float height);
- [Version (since = "1.6")]
- public void set_origin (Clutter.Vertex origin);
- [Version (since = "1.6")]
- public void set_width (float width);
- [Version (since = "1.6")]
- public void union (Clutter.PaintVolume another_pv);
- [Version (since = "1.10")]
- public void union_box (Clutter.ActorBox box);
- }
[CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_pan_action_get_type ()")]
[Version (since = "1.12")]
public class PanAction : Clutter.GestureAction {
@@ -6914,20 +6873,6 @@ namespace Clutter {
[CCode (has_construct_function = false)]
protected PipelineNode ();
}
- [CCode (cheader_filename = "clutter/clutter.h", copy_function = "g_boxed_copy", free_function =
"g_boxed_free", type_id = "clutter_point_get_type ()")]
- [Compact]
- [Version (since = "1.12")]
- public class Point {
- public float x;
- public float y;
- public static Clutter.Point alloc ();
- public Clutter.Point copy ();
- public float distance (Clutter.Point b, out float x_distance, out float y_distance);
- public bool equals (Clutter.Point b);
- public void free ();
- public unowned Clutter.Point init (float x, float y);
- public static unowned Clutter.Point zero ();
- }
[CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_property_transition_get_type ()")]
[Version (since = "1.10")]
public class PropertyTransition : Clutter.Transition, Clutter.Scriptable {
@@ -6937,32 +6882,6 @@ namespace Clutter {
public void set_property_name (string? property_name);
public string property_name { get; set; }
}
- [CCode (cheader_filename = "clutter/clutter.h", copy_function = "g_boxed_copy", free_function =
"g_boxed_free", type_id = "clutter_rect_get_type ()")]
- [Compact]
- [Version (since = "1.12")]
- public class Rect {
- public weak Clutter.Point origin;
- public weak Clutter.Size size;
- public static Clutter.Rect alloc ();
- public void clamp_to_pixel ();
- public bool contains_point (Clutter.Point point);
- public bool contains_rect (Clutter.Rect b);
- public Clutter.Rect copy ();
- public bool equals (Clutter.Rect b);
- public void free ();
- public void get_center (Clutter.Point center);
- public float get_height ();
- public float get_width ();
- public float get_x ();
- public float get_y ();
- public unowned Clutter.Rect init (float x, float y, float width, float height);
- public void inset (float d_x, float d_y);
- public bool intersection (Clutter.Rect b, Clutter.Rect? res);
- public Clutter.Rect normalize ();
- public void offset (float d_x, float d_y);
- public void union (Clutter.Rect b, Clutter.Rect res);
- public static unowned Clutter.Rect zero ();
- }
[CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_rectangle_get_type ()")]
[Version (since = "0.2")]
public class Rectangle : Clutter.Actor, Atk.Implementor, Clutter.Animatable, Clutter.Container,
Clutter.Scriptable {
@@ -7212,18 +7131,6 @@ namespace Clutter {
[CCode (has_construct_function = false)]
protected ShaderMatrix ();
}
- [CCode (cheader_filename = "clutter/clutter.h", copy_function = "g_boxed_copy", free_function =
"g_boxed_free", type_id = "clutter_size_get_type ()")]
- [Compact]
- [Version (since = "1.12")]
- public class Size {
- public float height;
- public float width;
- public static Clutter.Size alloc ();
- public Clutter.Size copy ();
- public bool equals (Clutter.Size b);
- public void free ();
- public unowned Clutter.Size init (float width, float height);
- }
[CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_snap_constraint_get_type ()")]
[Version (since = "1.6")]
public class SnapConstraint : Clutter.Constraint {
@@ -7546,7 +7453,7 @@ namespace Clutter {
public Clutter.Color get_cursor_color ();
public int get_cursor_position ();
[Version (since = "1.16")]
- public void get_cursor_rect (out unowned Clutter.Rect rect);
+ public Clutter.Rect get_cursor_rect ();
public uint get_cursor_size ();
public bool get_cursor_visible ();
public bool get_editable ();
@@ -7658,7 +7565,7 @@ namespace Clutter {
[Version (since = "1.16")]
public virtual signal void cursor_changed ();
[Version (deprecated = true, deprecated_since = "1.16", since = "1.0")]
- public virtual signal void cursor_event (Clutter.Geometry geometry);
+ public virtual signal Clutter.Geometry cursor_event ();
[HasEmitter]
[Version (since = "1.2")]
public signal void delete_text (int start_pos, int end_pos);
@@ -7811,7 +7718,7 @@ namespace Clutter {
[Version (since = "1.6")]
public bool get_auto_reverse ();
[Version (since = "1.12")]
- public bool get_cubic_bezier_progress (Clutter.Point c_1, Clutter.Point c_2);
+ public bool get_cubic_bezier_progress (out Clutter.Point c_1, out Clutter.Point c_2);
[Version (since = "1.10")]
public int get_current_repeat ();
[Version (since = "0.4")]
@@ -7990,8 +7897,8 @@ namespace Clutter {
public class ZoomAction : Clutter.GestureAction {
[CCode (has_construct_function = false, type = "ClutterAction*")]
public ZoomAction ();
- public void get_focal_point (Clutter.Point point);
- public void get_transformed_focal_point (Clutter.Point point);
+ public Clutter.Point get_focal_point ();
+ public Clutter.Point get_transformed_focal_point ();
public Clutter.ZoomAxis get_zoom_axis ();
public void set_zoom_axis (Clutter.ZoomAxis axis);
public Clutter.ZoomAxis zoom_axis { get; set; }
@@ -8162,7 +8069,7 @@ namespace Clutter {
[NoWrapper]
public abstract void add_redraw_clip (Clutter.Geometry stage_rectangle);
[NoWrapper]
- public abstract void get_geometry (Clutter.Geometry geometry);
+ public abstract void get_geometry (out Clutter.Geometry geometry);
[NoWrapper]
public abstract int get_pending_swaps ();
[NoWrapper]
@@ -8190,7 +8097,7 @@ namespace Clutter {
[NoWrapper]
public abstract void unrealize ();
}
- [CCode (cheader_filename = "clutter/clutter.h", type_id = "CLUTTER_TYPE_ACTOR_BOX")]
+ [CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_actor_box_get_type ()")]
public struct ActorBox {
public float x1;
public float y1;
@@ -8209,7 +8116,7 @@ namespace Clutter {
[Version (since = "1.0")]
public void free ();
[CCode (cname = "clutter_actor_box_from_vertices")]
- public ActorBox.from_vertices (Clutter.Vertex[] verts);
+ public ActorBox.from_vertices ([CCode (array_length = false)] Clutter.Vertex verts[4]);
[Version (since = "1.0")]
public float get_area ();
[Version (since = "1.0")]
@@ -8315,6 +8222,16 @@ namespace Clutter {
public bool equal (Clutter.Knot knot_b);
public void free ();
}
+ [CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_margin_get_type ()")]
+ [Version (since = "1.10")]
+ public struct Margin {
+ public float left;
+ public float right;
+ public float top;
+ public float bottom;
+ public Clutter.Margin? copy ();
+ public void free ();
+ }
[CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_matrix_get_type ()")]
[Version (since = "1.12")]
public struct Matrix : Cogl.Matrix {
@@ -8324,6 +8241,36 @@ namespace Clutter {
public unowned Clutter.Matrix? init_from_matrix (Clutter.Matrix b);
public unowned Clutter.Matrix? init_identity ();
}
+ [CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_paint_volume_get_type ()")]
+ [Version (since = "1.4")]
+ public struct PaintVolume {
+ [Version (since = "1.6")]
+ public Clutter.PaintVolume? copy ();
+ [Version (since = "1.6")]
+ public void free ();
+ [Version (since = "1.6")]
+ public float get_depth ();
+ [Version (since = "1.6")]
+ public float get_height ();
+ [Version (since = "1.6")]
+ public Clutter.Vertex get_origin ();
+ [Version (since = "1.6")]
+ public float get_width ();
+ [Version (since = "1.6")]
+ public void set_depth (float depth);
+ [Version (since = "1.6")]
+ public bool set_from_allocation (Clutter.Actor actor);
+ [Version (since = "1.6")]
+ public void set_height (float height);
+ [Version (since = "1.6")]
+ public void set_origin (Clutter.Vertex origin);
+ [Version (since = "1.6")]
+ public void set_width (float width);
+ [Version (since = "1.6")]
+ public void union (Clutter.PaintVolume another_pv);
+ [Version (since = "1.10")]
+ public void union_box (Clutter.ActorBox box);
+ }
[CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_path_node_get_type ()")]
[Version (since = "1.0")]
public struct PathNode {
@@ -8342,6 +8289,54 @@ namespace Clutter {
public float z_near;
public float z_far;
}
+ [CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_point_get_type ()")]
+ [Version (since = "1.12")]
+ public struct Point {
+ public float x;
+ public float y;
+ public static Clutter.Point? alloc ();
+ public Clutter.Point? copy ();
+ public float distance (Clutter.Point b, out float x_distance, out float y_distance);
+ public bool equals (Clutter.Point b);
+ public void free ();
+ public unowned Clutter.Point? init (float x, float y);
+ public static unowned Clutter.Point? zero ();
+ }
+ [CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_rect_get_type ()")]
+ [Version (since = "1.12")]
+ public struct Rect {
+ public Clutter.Point origin;
+ public Clutter.Size size;
+ public static Clutter.Rect? alloc ();
+ public void clamp_to_pixel ();
+ public bool contains_point (Clutter.Point point);
+ public bool contains_rect (Clutter.Rect b);
+ public Clutter.Rect? copy ();
+ public bool equals (Clutter.Rect b);
+ public void free ();
+ public Clutter.Point get_center ();
+ public float get_height ();
+ public float get_width ();
+ public float get_x ();
+ public float get_y ();
+ public unowned Clutter.Rect? init (float x, float y, float width, float height);
+ public void inset (float d_x, float d_y);
+ public bool intersection (Clutter.Rect b, out Clutter.Rect res);
+ public Clutter.Rect? normalize ();
+ public void offset (float d_x, float d_y);
+ public Clutter.Rect union (Clutter.Rect b);
+ public static unowned Clutter.Rect? zero ();
+ }
+ [CCode (cheader_filename = "clutter/clutter.h", type_id = "clutter_size_get_type ()")]
+ [Version (since = "1.12")]
+ public struct Size {
+ public float width;
+ public float height;
+ public static Clutter.Size? alloc ();
+ public Clutter.Size? copy ();
+ public bool equals (Clutter.Size b);
+ public void free ();
+ }
[CCode (cheader_filename = "clutter/clutter.h", type_id = "CLUTTER_TYPE_UNITS")]
[Version (since = "1.0")]
public struct Units {
diff --git a/vapi/metadata/Clutter-1.0-custom.vala b/vapi/metadata/Clutter-1.0-custom.vala
index 9b965bf2f..79d8e306d 100644
--- a/vapi/metadata/Clutter-1.0-custom.vala
+++ b/vapi/metadata/Clutter-1.0-custom.vala
@@ -1,8 +1,8 @@
namespace Clutter {
- [CCode (type_id = "CLUTTER_TYPE_ACTOR_BOX", cheader_filename = "clutter/clutter.h")]
+ [CCode (type_id = "clutter_actor_box_get_type ()", cheader_filename = "clutter/clutter.h")]
public struct ActorBox {
[CCode (cname = "clutter_actor_box_from_vertices")]
- public ActorBox.from_vertices (Clutter.Vertex[] verts);
+ public ActorBox.from_vertices ([CCode (array_length = false)] Clutter.Vertex verts[4]);
}
public struct Matrix : Cogl.Matrix {
@@ -85,7 +85,7 @@ namespace Clutter {
[NoWrapper]
public abstract void add_redraw_clip (Clutter.Geometry stage_rectangle);
[NoWrapper]
- public abstract void get_geometry (Clutter.Geometry geometry);
+ public abstract void get_geometry (out Clutter.Geometry geometry);
[NoWrapper]
public abstract int get_pending_swaps ();
[NoWrapper]
diff --git a/vapi/metadata/Clutter-1.0.metadata b/vapi/metadata/Clutter-1.0.metadata
index ceb4e35a2..9daf87c58 100644
--- a/vapi/metadata/Clutter-1.0.metadata
+++ b/vapi/metadata/Clutter-1.0.metadata
@@ -5,8 +5,13 @@ Fog struct
Geometry struct
Knot struct
Matrix struct
+Margin struct
+PaintVolume struct
PathNode struct
Perspective struct
+Point struct
+Rect struct
+Size struct
Units struct
Vertex struct
@@ -42,7 +47,8 @@ value_get_fixed nullable
// method/virtual-method/signal don't match
Actor
.event#method name="emit_event"
- .get_paint_volume#method skip
+ .get_paint_volume#virtual_method name="get_paint_volume_vfunc"
+ .get_paint_volume#virtual_method.volume out
.queue_redraw#signal skip
.queue_redraw#virtual_method skip
Container
@@ -148,6 +154,10 @@ Units.from_* skip
Color
.new skip
.from_* skip
+Margin
+ .new skip
+Size
+ .init skip
Vertex.new skip
// Class methods
@@ -160,26 +170,17 @@ get_input_device_for_id parent="Clutter.InputDevice" name="get_for_id"
color_from_* skip
units_from_* skip
-// Classes marked as out but not double ptr
-Actor
- .get_margin.margin out=false
-DragAction
- .get_drag_area.drag_area out=false
-InputDevice
- .get_coords.point out=false
-Rect
- .get_center.center out=false
- .intersection.res out=false
- .union.res out=false
-Timeline
- .get_cubic_bezier_progress.c_* out=false
-ZoomAction
- .get_focal_point.point out=false
- .get_transformed_focal_point.point out=false
-
// Struct return values
color_get_static nullable
+// Upstream
+Effect
+ .get_paint_volume.volume out
+Event
+ .get_position.position out
+Text
+ .cursor_event.geometry out
+
// Remove for clutter-2.0
/////////////////////////
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]