Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 5 additions & 5 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,8 @@ jobs:
- version: unstable
mutter_pkg: libmutter-14-dev
- version: development-target
mutter_pkg: libmutter-14-dev
mutter_pkg: libmutter-18-dev
lightdm_vala: lightdm-vala
container:
image: ghcr.io/elementary/docker:${{ matrix.version }}

Expand All @@ -31,7 +32,7 @@ jobs:
- name: Install Dependencies
run: |
apt update
apt install -y desktop-file-utils libgdk-pixbuf2.0-dev libgnome-desktop-3-dev libgranite-dev libgtk-3-dev libhandy-1-dev liblightdm-gobject-1-dev ${{ matrix.mutter_pkg }} libx11-dev meson valac
apt install -y desktop-file-utils libgdk-pixbuf-2.0-dev libgnome-desktop-3-dev libgranite-dev libgtk-3-dev libhandy-1-dev libjson-glib-dev liblightdm-gobject-1-dev ${{ matrix.mutter_pkg }} libsoup-3.0-dev libx11-dev ${{ matrix.lightdm_vala }} meson valac
- name: Build
env:
DESTDIR: out
Expand Down Expand Up @@ -75,8 +76,8 @@ jobs:
DESTDIR: out
run: |
meson build
ninja -C build install
ninja -C build install

lint:
runs-on: ubuntu-latest

Expand All @@ -89,4 +90,3 @@ jobs:
run: |
io.elementary.vala-lint -d compositor
io.elementary.vala-lint -d src

4 changes: 0 additions & 4 deletions compositor/BackgroundBlurEffect.vala
Original file line number Diff line number Diff line change
Expand Up @@ -39,11 +39,7 @@ public class GreeterCompositor.BackgroundBlurEffect : Clutter.Effect {
}

construct {
#if HAS_MUTTER47
unowned var ctx = actor.context.get_backend ().get_cogl_context ();
#else
unowned var ctx = Clutter.get_default_backend ().get_cogl_context ();
#endif

actor_pipeline = new Cogl.Pipeline (ctx);
actor_pipeline.set_layer_null_texture (0);
Expand Down
13 changes: 13 additions & 0 deletions compositor/KeyboardManager.vala
Original file line number Diff line number Diff line change
Expand Up @@ -48,10 +48,12 @@ public class GreeterCompositor.KeyboardManager : Object {

[CCode (instance_pos = -1)]
public static bool handle_modifiers_accelerator_activated (Meta.Display display, bool backward) {
#if !HAS_MUTTER50
#if HAS_MUTTER46
display.get_compositor ().backend.ungrab_keyboard (display.get_current_time ());
#else
display.ungrab_keyboard (display.get_current_time ());
#endif
#endif

var sources = settings.get_value ("sources");
Expand Down Expand Up @@ -79,7 +81,11 @@ public class GreeterCompositor.KeyboardManager : Object {
private void set_keyboard_layout (GLib.Settings settings, string key) {
unowned var backend = display.get_context ().get_backend ();

#if HAS_MUTTER50
if (key == "sources" || key == "xkb-options" || key == "current") {
#else
if (key == "sources" || key == "xkb-options") {
#endif
string[] layouts = {}, variants = {};

var sources = settings.get_value ("sources");
Expand Down Expand Up @@ -111,7 +117,12 @@ public class GreeterCompositor.KeyboardManager : Object {
cancellable = new GLib.Cancellable ();
}

#if HAS_MUTTER50
var description = new Meta.KeymapDescription.from_rules (settings.get_string ("xkb-model"), layout, variant, options, layouts, layouts);
backend.set_keymap_async.begin (description, settings.get_uint ("current"), cancellable, (obj, res) => {
#else
backend.set_keymap_async.begin (layout, variant, options, settings.get_string ("xkb-model"), cancellable, (obj, res) => {
#endif
try {
((Meta.Backend) obj).set_keymap_async.end (res);
} catch (Error e) {
Expand All @@ -128,6 +139,7 @@ public class GreeterCompositor.KeyboardManager : Object {
#else
backend.set_keymap (layout, variant, options);
#endif
#if !HAS_MUTTER50
} else if (key == "current") {
#if HAS_MUTTER49
if (cancellable != null) {
Expand All @@ -148,6 +160,7 @@ public class GreeterCompositor.KeyboardManager : Object {
});
#else
backend.lock_layout_group (settings.get_uint ("current"));
#endif
#endif
}
}
Expand Down
11 changes: 11 additions & 0 deletions compositor/meson.build
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,17 @@ if mutter49_dep.found()
vala_flags = ['--define', 'HAS_MUTTER46', '--define', 'HAS_MUTTER47', '--define', 'HAS_MUTTER48', '--define', 'HAS_MUTTER49']
endif

mutter50_dep = dependency('libmutter-18', version: ['>= 50', '< 51'], required: false)
if mutter50_dep.found()
libmutter_dep = dependency('libmutter-18', version: '>= 50')
mutter_dep = [
libmutter_dep,
dependency('mutter-mtk-18'), dependency('mutter-cogl-18'),
dependency('mutter-clutter-18')
]
vala_flags = ['--define', 'HAS_MUTTER46', '--define', 'HAS_MUTTER47', '--define', 'HAS_MUTTER48', '--define', 'HAS_MUTTER49', '--define', 'HAS_MUTTER50']
endif

if mutter_dep.length() == 0
error ('No supported mutter library found!')
endif
Expand Down
146 changes: 146 additions & 0 deletions vapi/Clutter-18.metadata
Original file line number Diff line number Diff line change
@@ -0,0 +1,146 @@
// Non mini-object
ActorBox struct
Margin struct
PaintVolume struct
Perspective struct

*.ref unowned
* cheader_filename="clutter/clutter.h"

// Fix the few clutter-pango headers
Text cheader_filename="clutter/clutter-pango.h"
TextBuffer cheader_filename="clutter/clutter-pango.h"
TextNode cheader_filename="clutter/clutter-pango.h"
Actor
.get_pango_context cheader_filename="clutter/clutter-pango.h"
.create_pango_context cheader_filename="clutter/clutter-pango.h"
.create_pango_layout cheader_filename="clutter/clutter-pango.h"


Actor
.apply_transform.matrix ref
.get_abs_allocation_vertices.verts out=false
Event.type#method name="get_type"

// ???
Actor.has_pointer#method name="get_has_pointer"

// Not all backing symbols are deprecated
Actor.pick deprecated=false

// Nullable return values
Actor
.get_parent nullable

// The original CType has been overridden by the annotations
Actor
.allocate.box ctype="const ClutterActorBox *"
.get_stage ctype="ClutterActor *"
Action.handle_event.event ctype="const ClutterEvent *"

// method/virtual-method/signal don't match
Actor
.event#method name="emit_event"
.get_paint_volume#virtual_method name="get_paint_volume_vfunc"
.get_paint_volume#virtual_method.volume out
Text
.activate#method name="try_activate"
.insert_text#signal skip
TextBuffer.get_text#virtual_method name="get_text_with_length"

// Default values
Stage.read_pixels
.width default=-1
.height default=-1
Stage.paint_to_buffer
.data type="uint8[]"
Text
.position_to_coords.line_height default=null

// Skipped by g-i for unknown reasons
LayoutManager
.create_child_meta skip=false

// We can use static strings
PaintNode
.set_static_name skip=false

// Variadic arguments
Backend
.get_cogl_context skip=false
Interval
.new skip=false
.get_interval skip=false
.set_final skip=false
.set_initial skip=false
.set_interval skip=false
LayoutManager
.child_get skip=false
.child_set skip=false

// Skipped upstream for unknown reasons
Interval.register_progress_func skip=false

// struct/class confusion
ActorBox
.new skip
.from_vertices skip
Margin
.new skip

// Upstream
Event
.get_position.position out

FrameListenerIface skip
FrameClock.new skip

// Remove for clutter-2.0
/////////////////////////

StageView.layout skip

Stage
.paint_view.redraw_clip type="Cairo.Region"

// *Event should be compact classes derived from Clutter.Event
Event.type skip=false
AnyEvent struct=false base_type="Clutter.Event"
ButtonEvent struct=false base_type="Clutter.Event"
CrossingEvent struct=false base_type="Clutter.Event"
DeviceEvent struct=false base_type="Clutter.Event"
IMEvent struct=false base_type="Clutter.Event"
KeyEvent struct=false base_type="Clutter.Event"
MotionEvent struct=false base_type="Clutter.Event"
PadButtonEvent struct=false base_type="Clutter.Event"
PadDialEvent struct=false base_type="Clutter.Event"
PadRingEvent struct=false base_type="Clutter.Event"
PadStripEvent struct=false base_type="Clutter.Event"
ProximityEvent struct=false base_type="Clutter.Event"
ScrollEvent struct=false base_type="Clutter.Event"
TouchEvent struct=false base_type="Clutter.Event"
TouchpadHoldEvent struct=false base_type="Clutter.Event"
TouchpadPinchEvent struct=false base_type="Clutter.Event"
TouchpadSwipeEvent struct=false base_type="Clutter.Event"

// Keysyms used to be CLUTTER_X instead of CLUTTER_KEY_X
*#constant skip
CURRENT_TIME skip=false
PRIORITY_REDRAW skip=false

// Clutter devs don't like us creating nested namespaces
value_* name="value_(.+)" parent="Clutter.Value"
threads_* name="threads_(.+)" parent="Clutter.Threads"

// There is no way to know sealed classes before GLib 2.70
ColorState sealed
FrameClock sealed
TextureContent sealed

TextureContent.new_from_texture symbol_type="constructor"

// Possibly keep
KEY_* skip=false name="KEY_(.+)" type="uint" parent="Clutter.Key"
BUTTON_* skip=false name="BUTTON_(.+)" type="uint32" parent="Clutter.Button"
EVENT_STOP skip=false type="bool"
EVENT_PROPAGATE skip=false type="bool"
66 changes: 66 additions & 0 deletions vapi/Cogl-18-custom.vala
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
namespace Cogl {
public struct Color {
[CCode (cname="cogl_color_init_from_4f")]
public Color.from_4f (float red, float green, float blue, float alpha);
[CCode (cname="cogl_color_init_from_hsl")]
public Color.from_hsl (float hue, float saturation, float luminance);
[CCode (cname = "_vala_cogl_color_from_string")]
public static Cogl.Color? from_string (string str) {
Cogl.Color color = {};
if (color.init_from_string (str))
return color;

return null;
}
}
[CCode (cheader_filename = "cogl/cogl.h", has_type_id = false)]
public struct VertexP2 {
public float x;
public float y;
}
[CCode (cheader_filename = "cogl/cogl.h", has_type_id = false)]
public struct VertexP2C4 {
public float x;
public float y;
public uint8 r;
public uint8 g;
public uint8 b;
public uint8 a;
}
[CCode (cheader_filename = "cogl/cogl.h", has_type_id = false)]
public struct VertexP2T2 {
public float x;
public float y;
public float s;
public float t;
}
[CCode (cheader_filename = "cogl/cogl.h", has_type_id = false)]
public struct VertexP2T2C4 {
public float x;
public float y;
public float s;
public float t;
public uint8 r;
public uint8 g;
public uint8 b;
public uint8 a;
}
[CCode (cheader_filename = "cogl/cogl.h", has_type_id = false)]
public struct VertexP3 {
public float x;
public float y;
public float z;
}
[CCode (cheader_filename = "cogl/cogl.h", has_type_id = false)]
public struct VertexP3T2 {
public float x;
public float y;
public float z;
public float s;
public float t;
}
[CCode (cheader_filename = "cogl/cogl.h", cprefix = "COGL_PIXEL_FORMAT_", type_id = "cogl_pixel_format_get_type ()")]
public enum PixelFormat {
CAIRO_ARGB32_COMPAT;
}
}
40 changes: 40 additions & 0 deletions vapi/Cogl-18.metadata
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
* cheader_filename="cogl/cogl.h"

Color struct

Color.equal.v1 type="Cogl.Color"
Color.equal.v2 type="Cogl.Color"
Color.from_string name="init_from_string"

Bitmap.* skip=false
Bitmap.new_for_data.data type="owned uint8[]"
Bitmap.get_buffer type="unowned Cogl.Buffer?"

Primitive.new skip=false

Texture
.get_data.data type="uint8[]"
.set_data.data type="uint8[]"
.set_region.data type="uint8[]"

Texture2D
.new_from_data skip=false

Texture.error_quark parent="Cogl.TextureError" name="quark"

RendererError errordomain
SystemError errordomain
TextureError errordomain
FramebufferError errordomain
ScanoutError errordomain

Onscreen
.add_frame_callback unowned

A_BIT parent="Cogl.Bits" name="A"
BGR_BIT parent="Cogl.Bits" name="BGR"
AFIRST_BIT parent="Cogl.Bits" name="AFIRST"
PREMULT_BIT parent="Cogl.Bits" name="PREMULT"
DEPTH_BIT parent="Cogl.Bits" name="DEPTH"
STENCIL_BIT parent="Cogl.Bits" name="STENCIL"
PIXEL_FORMAT_MAX_PLANES parent = "Cogl.PixelFormat" name="MAX_PLANES"
5 changes: 5 additions & 0 deletions vapi/Meta-18-custom.vala
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
namespace Meta.Util {
public static inline bool is_wayland_compositor () {
return true;
}
}
Loading