Bilal Elmoussaoui
f5c376e860
cogl: Move PrimitiveTexture functions to Texture
...
Since the move to GObject for CoglTexture, CoglPrimitiveTexture was
removed. So drop remaining of that.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3885 >
2024-07-15 21:42:38 +02:00
Bilal Elmoussaoui
1d465461a7
cogl: Remove default context gross hack
...
As nothing uses it anymore
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3857 >
2024-07-15 14:39:23 +00:00
Bilal Elmoussaoui
c23bc80ba4
cogl/debug: Take a context param
...
This will make the usage through gdb not as useful as it was
but it is the last remaining usage of a gross hack, so let us get rid of it
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3857 >
2024-07-15 14:39:23 +00:00
Bilal Elmoussaoui
c1733e8d7c
cogl: Keep a backpointer to context/display
...
Allows to retrieve the context from the renderer, allows
to get rid of one GET_CONTEXT usages
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3857 >
2024-07-15 14:39:23 +00:00
Bilal Elmoussaoui
725e826a39
cogl: Require a Renderer/Display when initializing
...
The whole fallbacks all over the place were only useful when Cogl was a separate
library
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3857 >
2024-07-15 14:39:23 +00:00
Bilal Elmoussaoui
54748b7f1f
cogl: Call init when creating a context from Clutter
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3857 >
2024-07-15 14:39:23 +00:00
Bilal Elmoussaoui
9ee1a0fc34
cogl: Expose Renderer.get_proc_address
...
Allows to get rid of the cogl_get_proc_address
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3857 >
2024-07-15 14:39:23 +00:00
Bilal Elmoussaoui
b3ae934304
cogl: Pass Context to cogl_flush
...
Avoids using the global variable & also move the function to
it proper context
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3857 >
2024-07-15 14:39:23 +00:00
Bilal Elmoussaoui
194fa80cdd
cogl: Pass a Context param to winsys_has_feature
...
Avoids using the global variable
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3857 >
2024-07-15 14:39:23 +00:00
Bilal Elmoussaoui
3fd7cdba09
cogl: Pass Context where possible
...
Avoids using the macro & global variable
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3857 >
2024-07-15 14:39:23 +00:00
Bilal Elmoussaoui
24f46448ce
cogl/pango: Take a context as a param when constructing a font map
...
Avoids using the get_context macro
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3857 >
2024-07-15 14:39:23 +00:00
Jonas Ådahl
9a0fbbfa81
cogl/pango: Add argument to supply extra snippet
...
This will be applied to the pipeline used for drawing, and can be used
to include color state transformation snippets.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3433 >
2024-07-09 18:56:07 +02:00
Jonas Ådahl
fe63242d60
cogl: Include the pipeline name and program number in debug logs
...
When running with COGL_DEBUG=show-source, log what pipeline and shader
program is used when painting, and what shader source code corresponds
to each shader program.
This helps identify what shader is used when painting to what
framebuffer.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3433 >
2024-07-09 18:56:07 +02:00
Jonas Ådahl
aaba08e5aa
Set names of various Cogl pipelines
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3433 >
2024-07-09 18:56:07 +02:00
Jonas Ådahl
6cd28a84ac
cogl/pipeline: Add API to name a pipeline
...
It uses static strings, and is meant to make it easier to match what
pipeline source code one might be looking at when running with
COGL_DEBUG=show-sources.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3433 >
2024-07-09 18:56:07 +02:00
Jonas Ådahl
f67ace517f
cogl/snippet: Add way to add an opaque capability
...
A snippet is assigned a capability, which is then transferred to the
pipeline it gets added to. Managers of pipelines can then check whether
a pipeline it got handed whether it has a certain capability, and if
not, handle the situation where it is not.
The intention is to allow Clutter to tag color state transformation
snippets with a capability, allowing generic paint nodes to handle color
transformations when needed.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3433 >
2024-07-09 18:56:07 +02:00
Jonas Ådahl
1fa5a016be
cogl/gl: Bump required GLSL version to 140
...
This will be needed by future color management and HDR shaders.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3433 >
2024-07-09 18:00:58 +02:00
Jonas Ådahl
2ae5af62ea
clutter/stage-view: Make shadow fbs use the onscreen pixel format
...
We'd use the "default" format otherwise; once the onscreen gets
something other than the hard coded format, we'll want to make sure we
use the same here.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3433 >
2024-07-09 18:00:58 +02:00
Bilal Elmoussaoui
bfd7f9d549
build: Split X11 server & client dependencies
...
Allows xwayland=true x11=false to be built with less dependencies
Also removes some unused x11 dependencies on the frame client & cogl
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3853 >
2024-06-30 15:09:00 +02:00
Bilal Elmoussaoui
820a7ad813
build: Allow building xwayland without x11
...
Co-authored-by: Jonas Ådahl <jadahl@gmail.com>
Closes https://gitlab.gnome.org/GNOME/mutter/-/issues/3553
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3853 >
2024-06-30 15:08:55 +02:00
Jonas Ådahl
422ee4515d
Compile with -Wfloat-conversion
...
This means we'll get warnings whenever a floating point value looses
precision, e.g. gets implicitly casted to an integer. It also warns when
implicitly casting double's to float's, which arguably is less of a
problem, but there are no warning for just float/double to int.
This would have caught
https://gitlab.gnome.org/GNOME/mutter/-/issues/3530 .
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3822 >
2024-06-25 20:48:24 +02:00
Bilal Elmoussaoui
6e1c761330
Remove unused variables
...
Detected through codeql
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3837 >
2024-06-22 23:53:49 +00:00
Bilal Elmoussaoui
b0aacf4093
cogl: Mark XlibRenderer.get_display private
...
Nothing uses it externally, take the opportunity to remove an unused function
as well
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3813 >
2024-06-18 13:32:13 +00:00
Bilal Elmoussaoui
8b2aa05103
cogl: Remove no longer useful headers
...
I suppose they were useful at times when cogl was a separate library
where you could use cogl- but that is no longer a thing
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3813 >
2024-06-18 13:32:13 +00:00
Bilal Elmoussaoui
f004b560fc
cogl/texture: Avoid helper methods that just chain up
...
This was needed pre-GObjectified CoglTexture, not neccessary anymore
so clean those up a little bit
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3818 >
2024-06-18 13:21:56 +00:00
Bilal Elmoussaoui
a71e39b0e0
cogl: Remove unused TextureChangeFlags
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3818 >
2024-06-18 13:21:56 +00:00
Bilal Elmoussaoui
06402fd756
cogl: Remove unused TexturePixel
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3818 >
2024-06-18 13:21:56 +00:00
Bilal Elmoussaoui
c9c64f0990
cogl/pango: Remove various unused private functions
...
A quick cleanup in preparation for moving cogl-pango to libst later
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3823 >
2024-06-18 10:43:20 +00:00
Bilal Elmoussaoui
0064bf240e
cogl: Remove unused immutable_ref
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3810 >
2024-06-14 21:16:05 +02:00
Bilal Elmoussaoui
69835c9ec1
cogl: Remove CoglFence
...
Nothing was really using it...I am removing too much?
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3806 >
2024-06-14 12:12:34 +02:00
Bilal Elmoussaoui
4eb555a2f0
cogl: Remove unused Texture2DSliced.new_from_data
...
Nothing uses it and can be re-implemented externally if needed anyways.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3806 >
2024-06-14 12:12:33 +02:00
Bilal Elmoussaoui
4f896e55d6
cogl: Remove header-only functions
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3806 >
2024-06-14 12:12:33 +02:00
Bilal Elmoussaoui
e638e5dfab
cogl: Remove unused OnScreen dirty_closures
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3806 >
2024-06-14 12:12:33 +02:00
Bilal Elmoussaoui
47d427a95d
cogl: Remove unused BufferTarget
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3806 >
2024-06-14 12:12:33 +02:00
Bilal Elmoussaoui
218b77c739
cogl: Replace DamageRectangle with MtkRectangle
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3806 >
2024-06-14 12:12:33 +02:00
Bilal Elmoussaoui
aa0600bf27
cogl: Remove Framebuffer:stereo-mode
...
Nothing was setting it
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3806 >
2024-06-14 12:12:33 +02:00
Bilal Elmoussaoui
9097deb69d
cogl: Remove various Framebuffer functions
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3806 >
2024-06-14 12:12:33 +02:00
Bilal Elmoussaoui
2c996a1b16
build/cogl: Simplify debug c-args
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3806 >
2024-06-14 12:12:33 +02:00
Bilal Elmoussaoui
e79f460eb8
cogl: Remove FrameBuffer CoglObject leftover
...
Fixes: eb14da387
("cogl: Turn CoglFramebuffer, CoglOffscreen and
CoglOnscreen into GObjects")
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3806 >
2024-06-14 12:12:33 +02:00
Marco Trevisan (Treviño)
03ef333937
cogl/context: Add test util function to get the GL/GLES driver vendor
...
Some tests sadly behaves differently depending on the driver in use.
While this shouldn't happen we can't block on these driver issues, so
add a test utils private function to get the driver information so that
we can adapt test behavior depending on this.
This will allow to disable / enable tests at runtime instead of failing
in all the implementations, which is still better for catching
regressions in the parts we may be ignoring otherwise.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3793 >
2024-06-13 21:21:49 +00:00
Bilal Elmoussaoui
3e363a5421
cogl/pipeline-debug: Use Color helper to get a string representation
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3544 >
2024-06-13 21:19:54 +02:00
Bilal Elmoussaoui
93ded65b7d
cogl: Make sure alpha is correctly set for hsla Colors
...
As the color is initiallized with init_from_hls which always sets
alpha to 1.0
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3544 >
2024-06-13 14:45:53 +02:00
Bilal Elmoussaoui
5851738db4
cogl: Stop hardcoding Color size
...
Especially that the fields are public now and with a potential
migration to floats.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3544 >
2024-06-13 14:45:53 +02:00
Bilal Elmoussaoui
5f22fddc26
cogl: Make Color fields public
...
To simplify the porting to CoglColor in the future as ClutterColor
fields are public
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3544 >
2024-06-13 14:45:53 +02:00
Bilal Elmoussaoui
a12e707324
cogl: Implement transform from/to string for CoglColor values
...
Same as previous commits
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3544 >
2024-06-13 14:45:53 +02:00
Bilal Elmoussaoui
28f702ce1a
cogl: Copy ColorParamSpec from clutter
...
Follow up of previous commit
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3544 >
2024-06-13 14:45:53 +02:00
Bilal Elmoussaoui
ac3aa35489
cogl: Add missing functions from ClutterColor to CoglColor
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3544 >
2024-06-13 14:45:53 +02:00
Bilal Elmoussaoui
014ea91a9d
cogl: Remove various DepthState functions
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3804 >
2024-06-12 00:42:45 +00:00
Bilal Elmoussaoui
bb29fa68fe
cogl: Remove AtlasTexture.new_from_data
...
Nothing uses it, allows to drop the corresponding test case as well
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3804 >
2024-06-12 00:42:45 +00:00
Bilal Elmoussaoui
94c2c41b66
cogl: Remove unused features functions
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3804 >
2024-06-12 00:42:45 +00:00
Bilal Elmoussaoui
ed0ee25843
cogl: Remove header-only Pipeline functions
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3804 >
2024-06-12 00:42:45 +00:00
Bilal Elmoussaoui
863d4ad6d6
cogl: Remove various unused MatrixEntry functions
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3804 >
2024-06-12 00:42:45 +00:00
Bilal Elmoussaoui
adf0acbe0d
cogl: Remove various unused Attribute functions
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3804 >
2024-06-12 00:42:45 +00:00
Georges Basile Stavracas Neto
bc7134cab3
cogl: Remove CoglOutput
...
Begone!
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3792 >
2024-06-03 08:31:58 +00:00
Georges Basile Stavracas Neto
cb4190616f
cogl/xlib-renderer: Use SubpixelFormat enums directly
...
No need to convert from / to CoglSubpixelFormat.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3792 >
2024-06-03 08:31:58 +00:00
Georges Basile Stavracas Neto
4f3631eae4
cogl/xlib-renderer: Don't override subpixel order
...
This function goes to great lengths to convert an Xlib SubpixelFormat
enum into a CoglSubpixelFormat, then immediately discards that.
Fixes 88d8bd84f2
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3792 >
2024-06-03 08:31:58 +00:00
Georges Basile Stavracas Neto
2a9576c59c
cogl/xlib-renderer: Plug some leaks
...
Found them while reworking this file. XRRFree*Info() fully free the
pointers inside the infos, they're more appropriate.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3792 >
2024-06-03 08:31:58 +00:00
Georges Basile Stavracas Neto
64d0e503ff
cogl/xlib-renderer: Copy CoglOutput struct
...
Since CoglOutput is strictly only used internally by Xlib and GLX,
copy it in place and use it.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3792 >
2024-06-03 08:31:58 +00:00
Georges Basile Stavracas Neto
c9e22d9f79
cogl/xlib-renderer: Return refresh rate directly
...
Instead of a CoglOutput that is then only used to fetch the refresh
rate.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3792 >
2024-06-03 08:31:58 +00:00
Georges Basile Stavracas Neto
653ba4a7a7
cogl/renderer: Move output list to CoglXlibRenderer
...
It's the only place where it's used.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3792 >
2024-06-03 08:31:58 +00:00
Georges Basile Stavracas Neto
94d69c3252
cogl/onscreen-glx: Store refresh rate directly
...
Instead of the CoglOutput. This removes any necessity of refcounting,
and allows simplifying some code.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3792 >
2024-06-03 08:31:58 +00:00
Georges Basile Stavracas Neto
c1c8a4ba09
cogl/output: Make it private to Cogl
...
Don't expose its headers, remove all getters, and move the rest to
cogl-output-private.h. Next commits will clean it up even more, but
for now, just make it private.
This will help next commits remove CoglOutput.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3792 >
2024-06-03 08:31:58 +00:00
Georges Basile Stavracas Neto
3ba7f626ed
cogl: Remove unecessary includes
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3792 >
2024-06-03 08:31:58 +00:00
Marco Trevisan (Treviño)
bcec6df78e
cogl: Do not store the XVisualInfo
...
We were leaking one instance because _cogl_winsys_egl_context_created()
could be potentially be called twice (via cogl_display_setup() one as
part of cogl_renderer_check_onscreen_template() and the other when
called from clutter_backend_do_real_create_context()), and so we'd ended
up overwriting the reference we had.
However, we really didn't use it anywhere and once used to call the
relevant functions it's just useless.
So let's just keep it as local variable
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3788 >
2024-05-31 11:01:00 +00:00
Georges Basile Stavracas Neto
06dde49d12
cogl/renderer: Remove dead code
...
Introduced by dad9f64b5f
, but wasn't caught on review.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3782 >
2024-05-27 10:29:10 +02:00
Bilal Elmoussaoui
b054a09aa1
cogl: Remove unnused Renderer.foreach_output
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3781 >
2024-05-26 16:12:48 +02:00
Bilal Elmoussaoui
c506c194b6
cogl: Don't allow overriding renderer winsys_id
...
It is an API that no longer makes sense, as Cogl is only usable inside of Mutter
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3781 >
2024-05-26 16:11:47 +02:00
Bilal Elmoussaoui
dad9f64b5f
cogl: Don't allow overriding renderer constraints
...
It is an API that no longer makes sense, as Cogl is only usable inside of Mutter
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3781 >
2024-05-26 16:10:21 +02:00
Jonas Ådahl
c192f51159
cogl: Add sync fd feature enum value
...
This is meant to tell whether cogl_context_get_latest_sync_fd() is
supposed to work or not. It's enabled when ANDROID_native_fence_sync is
exposed by the driver.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3771 >
2024-05-23 16:42:21 +00:00
Bilal Elmoussaoui
5cac24346d
cogl: Remove unused DEFAULT_DRIVER code
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3762 >
2024-05-21 09:38:35 +00:00
Bilal Elmoussaoui
5752704886
cogl: Remove COGL_RENDERER env variable
...
Doesn't seem to be that useful with Cogl being embedded inside Mutter nowadays.
Spotted by Georges
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3762 >
2024-05-21 09:38:35 +00:00
Georges Basile Stavracas Neto
638d3355b4
cogl: Drop CoglSwapChain
...
CoglSwapChain is currently unused, and doesn't hold any information
nor is used for anything in particular.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3759 >
2024-05-20 11:45:31 +00:00
Bilal Elmoussaoui
fc623c1ed1
build: Enable -Werror=shadow and fix related issues
...
Mostly renames or removing already defined types
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3378 >
2024-05-06 15:54:16 +00:00
Michel Dänzer
09267d0bdd
cogl/onscreen: Add cogl_onscreen_egl_maybe_create_timestamp_query
...
Move the code out of cogl_onscreen_egl_swap_buffers_with_damage, and
call the new function from callers of the former.
v2:
* Use early return if the cogl context doesn't support timestamp
queries. (Sebastian Wick)
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3689 >
2024-04-10 11:17:23 +02:00
Michel Dänzer
0bbc25f694
cogl: Update latest sync fd from cogl_onscreen_swap_buffers_with_damage
...
Preparation for later changes, no functional change intended.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3689 >
2024-04-10 11:17:19 +02:00
Bilal Elmoussaoui
34d79b9ddf
cogl: Make sure generated enum header is built before sources using it
...
Fixes: 63a558950
("cogl: Generate a GType for PixelFormat")
Closes https://gitlab.gnome.org/GNOME/mutter/-/issues/3413
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3690 >
2024-04-07 14:29:07 +00:00
Bilal Elmoussaoui
260a8d92dc
cogl: Use uint64_t for size params
...
As we are using a GParamSpecUint64 for that property
which makes it fail under 32bits platforms
Fixes: 6efd4a228
("cogl/cleanup: Use construct-only properties for
CoglBuffer")
Closes https://gitlab.gnome.org/GNOME/mutter/-/issues/3408
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3683 >
2024-04-03 14:30:49 +00:00
Austin Shafer
99209958b9
cogl: Store latest GPU work completed sync fd
...
This keeps an internal sync_fd for the latest work submitted to
the GPU. This can then be fetched with cogl_context_get_latest_sync_fd
for use. This is intended for use with linux-drm-syncobj-v1
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3300 >
2024-03-28 13:27:42 -04:00
Robert Mader
683e917854
cogl/winsys: Remove eglGetProcAddress workaround for EGL < 1.5
...
`eglGetProcAddress()` used to not work for core API in EGL versions
below 1.5. The workaround in place in turn can fail - notably for setups
with a local Mesa build in /usr/local.
EGL 1.5 is almost 10 years old and similar workarounds don't seem to be
in place for toolkits we rely on, notably GTK4. Thus remove it.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3655 >
2024-03-13 16:37:31 +01:00
Robert Mader
aaae07f9dd
onscreen/native: Mark GPU rendering duration as valid if supported
...
Since commit e30eb78891
`ClutterFrameClock` assumes that a valid CPU time
implies timestamp query support, which is also checked in
`cogl_onscreen_egl_swap_buffers_with_damage()`.
Unconditionally setting the CPU time on direct scanout meant that the
compositing path would be stuck on the last (direct scanout optimized)
result on GL implementations without timestamp query support since.
be0aa2976e
(clutter/frame-clock: Avoid rapidly toggling dynamic max render time)
Fix that by explicitly marking the gpu rendering duration as valid when
querying the GPU timestamps is supported and check for it ClutterFrameClock.
Fixes: 56580ea7c9
("backends/native: Assume zero rendering time for direct scanout buffers")
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3655 >
2024-03-13 16:37:16 +01:00
Zander Brown
6a445d2eef
build: Make exported package in gir consistent
...
Additionally Cogl was missing xlib as an include
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1918 >
2024-03-13 12:52:41 +00:00
Corentin Noël
c4767b6c01
cogl: Increase annotation coverage
...
Upstream the annotations used in Gala, make more Cogl methods available since
things got moved to a GObject base and thus works natively with the introspection.
Add all the public API to the introspection.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3619 >
2024-02-27 14:45:29 +00:00
Bilal Elmoussaoui
60e10511ae
cogl: Remove Color.init_from_4ub
...
Slowly switching to using floats only in CoglColor
Helps https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3544
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3594 >
2024-02-22 12:34:58 +00:00
Bilal Elmoussaoui
cf0803ab71
cogl: Remove Color.get_*_byte
...
Helps with https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3544
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3594 >
2024-02-22 12:34:58 +00:00
Bilal Elmoussaoui
40dde833af
cogl: Remove Color.get_*_float
...
They are exactly the same as the get_* variants
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3594 >
2024-02-22 12:34:57 +00:00
Bilal Elmoussaoui
77f95d2203
cogl: Drop unused Color APIs
...
Simplifies the overall API as preparation of merging both
CoglColor and ClutterColor
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3594 >
2024-02-22 12:34:57 +00:00
Corentin Noël
e7de5c36f3
build: Remove the config.h inclusion from all public headers
...
Do not include it at header side as it is not part of the installed headers.
Only keep it in cogl-gl-headers.h as it is a private header.
Add it to all the source files that depend on it.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3593 >
2024-02-17 11:58:55 +00:00
Doğukan Korkmaztürk
34d00d769e
render-device: Update DMA-BUF allocation API to allow modifiers
...
meta_render_device_gbm_allocate_dma_buf() function is updated to take a
list of modifiers. If no modifiers are specified, the modifier is
selected by the allocator, and implicit modifiers are used to import the
created DMA-BUF.
Co-authored-by: Jonas Ådahl <jadahl@gmail.com>
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3537 >
2024-02-16 08:22:04 -05:00
Bilal Elmoussaoui
2c613df4eb
cogl: Drop Pipeline.set_color_*
...
Those setters variants makes it very hard to do across project changes
to the
color type. As part of
https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3544
I would like to switch from using integers to floats inside CoglColor
which this PR would simplify
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3553 >
2024-02-16 12:13:23 +01:00
Daniel van Vugt
c63fdba6b3
cogl/onscreen/glx: Remove extraneous spaces
...
check-code-style was complaining about this.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3587 >
2024-02-15 15:13:17 +08:00
Daniel van Vugt
53ca3a0089
cogl/onscreen/glx: Remove comment about clipped redraws not being supported
...
They've been supported for a very long time.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3587 >
2024-02-15 14:57:23 +08:00
Daniel van Vugt
ea486b200f
cogl/onscreen/glx: Remove duplicate wait function
...
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3587 >
2024-02-15 14:55:18 +08:00
Robert Mader
912cd80f10
cogl/scanout: Add API for source/destination rectangles
...
These will get passed on to KMS later.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3177 >
2024-02-10 17:41:12 +00:00
Robert Mader
52c4b85161
cogl: Turn CoglScanout into an object
...
We need an object to hold additional scanout related information, such
as scaling and positioning data. Turn CoglScanout into such an object,
moving the interface into CoglScanoutBuffer.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3177 >
2024-02-10 17:41:12 +00:00
Daniel van Vugt
c43f57f757
cogl/onscreen/glx: Fix x/y mixup used to identify the current output
...
I haven't seen this cause a problem but it looks like the worst case is
that it would have put the wrong refresh rate value in CoglFrameInfo
for multi-monitor systems of differing frequencies. But even that seems
unlikely given `_cogl_xlib_renderer_output_for_rectangle` chooses the
output with the greatest overlap of the partially-correct rectangle.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3569 >
2024-02-08 18:03:03 +08:00
Robert Mader
03c3b642bd
cogl: Move CoglScanout declarations from onscreen to types
...
While closely related, types appears to be the more appropriate place
these days.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3559 >
2024-02-02 17:40:37 +01:00
Bilal Elmoussaoui
f0ebc41205
cogl: Move cairo dependency to cogl-pango
...
As cairo is not used in cogl API
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3530 >
2024-01-27 10:03:15 +00:00
Bilal Elmoussaoui
a55b080129
gir: Remove unnused cairo include
...
As cairo is not used in the public API
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3530 >
2024-01-27 10:03:15 +00:00
Sebastian Wick
41a7e8e3e0
build: Make g-ir-scanner warnings fatal when -werror is set
...
This should help catching problems with introspection in CI.
This also pulls out some common arguments to the gnome.generate_gir
call.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3528 >
2024-01-17 09:26:00 +00:00
Sebastian Wick
db492fe335
cogl: Use COGL_ENABLE_DEBUG instead of COGL_DEBUG_ENABLED
...
COGL_DEBUG_ENABLED is a macro to check if a debug flag is set.
COGL_ENABLE_DEBUG is set by the build system if it's a debug build. The
check `#ifdef COGL_DEBUG_ENABLED` always evaluates to true. Use the
appropriate macro to guard some debugging code.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3446 >
2024-01-15 22:28:54 +00:00