Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[rcore] Overview of Wayland, Xwayland and X11 support on Linux #4371

Closed
ghost opened this issue Oct 7, 2024 · 2 comments
Closed

[rcore] Overview of Wayland, Xwayland and X11 support on Linux #4371

ghost opened this issue Oct 7, 2024 · 2 comments

Comments

@ghost
Copy link

ghost commented Oct 7, 2024

Note

- This post contains my opinions and observations, YMMV.
- Posting as an issue because it's a recurrent subject, but feel free to close this.

Context:

  1. Many Linux distributions are undergoing a migration from the X Window System (X11) to the Wayland communication protocol.
  2. However, a series of issues are emerging due to the architectural differences between both systems. E.g.: Wayland transfering some window control (like positioning) from the application to the window manager.
  3. These architectural choices make Wayland diverge from how other desktop operating systems handle windows.
  4. Since supporting Wayland requires rebuilding all graphical applications for it, Xwayland was provided as a backward compatibility solution to run X clients under Wayland.

Native Wayland limitations on GLFW:

Referencing the GLFW documentation:

GLFW function: Wayland limitation: Use in raylib:
glfwSetWindowIcon "Wayland: There is no existing protocol to change an icon, the window will thus inherit the one defined in the application's desktop file. This function will emit GLFW_FEATURE_UNAVAILABLE." SetWindowIcon
glfwGetWindowPos "Wayland: There is no way for an application to retrieve the global position of its windows. This function will emit GLFW_FEATURE_UNAVAILABLE." GetCurrentMonitor
GetWindowPosition
glfwSetWindowPos "Wayland: There is no way for an application to set the global position of its windows. This function will emit GLFW_FEATURE_UNAVAILABLE." ToggleBorderlessWindowed
SetWindowPosition
SetWindowMonitor
glfwSetWindowSizeLimits "Wayland: The size limits will not be applied until the window is actually resized, either by the user or by the compositor." SetWindowMinSize
SetWindowMaxSize
glfwSetWindowAspectRatio "Wayland: The aspect ratio will not be applied until the window is actually resized, either by the user or by the compositor." Not used.
glfwSetWindowOpacity "Wayland: There is no way to set an opacity factor for a window. This function will emit GLFW_FEATURE_UNAVAILABLE." SetWindowOpacity
glfwIconifyWindow "Wayland: Once a window is iconified, glfwRestoreWindow won’t be able to restore it. This is a design decision of the xdg-shell protocol." MinimizeWindow
glfwShowWindow "Wayland: Because Wayland wants every frame of the desktop to be complete, this function does not immediately make the window visible. Instead it will become visible the next time the window framebuffer is updated after this call." ClearWindowState
glfwFocusWindow "Wayland: The compositor will likely ignore focus requests unless another window created by the same application already has input focus." ToggleBorderlessWindowed
SetWindowFocused
glfwSetWindowMonitor "Wayland: The desired window position is ignored, as there is no way for an application to set this property." ToggleFullscreen
glfwGetWindowAttrib "Wayland: The Wayland protocol provides no way to check whether a window is iconfied, so GLFW_ICONIFIED always returns GLFW_FALSE." Not used on the limitation context.
glfwSetWindowAttrib "Wayland: The GLFW_FLOATING window attribute is not supported. Setting this will emit GLFW_FEATURE_UNAVAILABLE." InitPlatform
ToggleBorderlessWindowed
SetWindowState
ClearWindowState
glfwSetWindowPosCallback "Wayland: This callback will never be called, as there is no way for an application to know its global position." WindowPosCallback

These limitations can be tested with:

#include "raylib.h"
int main(void) {
    InitWindow(800, 450, "test");
    SetTargetFPS(60);
    Image red = GenImageColor(16, 16, RED);
    while (!WindowShouldClose()) {

        if(IsKeyPressed(KEY_R)) { SetWindowState(FLAG_WINDOW_RESIZABLE); TraceLog(LOG_INFO, "[R] SetWindowState(FLAG_WINDOW_RESIZABLE)"); }
        if(IsKeyPressed(KEY_E)) { ClearWindowState(FLAG_WINDOW_RESIZABLE); TraceLog(LOG_INFO, "[E] ClearWindowState(FLAG_WINDOW_RESIZABLE)"); }
        if(IsKeyPressed(KEY_H)) { SetWindowState(FLAG_WINDOW_HIDDEN); TraceLog(LOG_INFO, "[H] SetWindowState(FLAG_WINDOW_HIDDEN)"); }
        if(IsKeyPressed(KEY_J)) { ClearWindowState(FLAG_WINDOW_HIDDEN); TraceLog(LOG_INFO, "[J] ClearWindowState(FLAG_WINDOW_HIDDEN)"); }
        if(IsKeyPressed(KEY_T)) { SetWindowState(FLAG_WINDOW_TOPMOST); TraceLog(LOG_INFO, "[T] SetWindowState(FLAG_WINDOW_TOPMOST)"); }
        if(IsKeyPressed(KEY_Y)) { ClearWindowState(FLAG_WINDOW_TOPMOST); TraceLog(LOG_INFO, "[Y] ClearWindowState(FLAG_WINDOW_TOPMOST)"); }
        if(IsKeyPressed(KEY_NINE)) { SetWindowMaxSize(900, 600); TraceLog(LOG_INFO, "[9] SetWindowMaxSize(900, 600)"); }
        if(IsKeyPressed(KEY_ZERO)) { SetWindowMinSize(300, 200); TraceLog(LOG_INFO, "[0] SetWindowMinSize(300, 200)"); }
        if(IsKeyPressed(KEY_M)) { MinimizeWindow(); TraceLog(LOG_INFO, "[M] MinimizeWindow()"); }
        if(IsKeyPressed(KEY_F)) { ToggleFullscreen(); TraceLog(LOG_INFO, "[F] ToggleFullscreen()"); }
        if(IsKeyPressed(KEY_G)) { ToggleBorderlessWindowed(); TraceLog(LOG_INFO, "[G] ToggleBorderlessWindowed()"); }
        if(IsKeyPressed(KEY_P)) { SetWindowPosition(100, 100); TraceLog(LOG_INFO, "[P] SetWindowPosition(100, 100)"); }
        if(IsKeyPressed(KEY_O)) { SetWindowOpacity(0.5f); TraceLog(LOG_INFO, "[O] SetWindowOpacity(0.5f)"); }
        if(IsKeyPressed(KEY_I)) { SetWindowIcon(red); TraceLog(LOG_INFO, "[I] SetWindowIcon(red)"); }
        if(IsKeyPressed(KEY_U)) { SetWindowFocused(); TraceLog(LOG_INFO, "[U] SetWindowFocused()"); }
        if(IsKeyPressed(KEY_ONE)) { if (GetMonitorCount() > 0) { SetWindowMonitor(0); TraceLog(LOG_INFO, "[1] SetWindowMonitor(0), if available"); } }
        if(IsKeyPressed(KEY_TWO)) { if (GetMonitorCount() > 1) { SetWindowMonitor(1); TraceLog(LOG_INFO, "[2] SetWindowMonitor(1), if available"); } }

        BeginDrawing();
        ClearBackground(RAYWHITE);
        DrawText(TextFormat("current monitor: %i", GetCurrentMonitor()), 20, 20, 20, BLACK);
        DrawText(TextFormat("(monitor count: %i)", GetMonitorCount()), 220, 20, 20, BLACK);
        DrawText(TextFormat("window position: %.1f, %.1f", GetWindowPosition().x, GetWindowPosition().y), 20, 50, 20, BLACK);
        DrawText(TextFormat("window size: %i, %i", GetScreenWidth(), GetScreenHeight()), 20, 80, 20, BLACK);
        DrawText("[R] Set FLAG_WINDOW_RESIZABLE", 20, 120, 20, ORANGE);
        DrawText("[E] Clear FLAG_WINDOW_RESIZABLE", 20, 150, 20, ORANGE);
        DrawText("[H] Set FLAG_WINDOW_HIDDEN", 20, 190, 20, RED);
        DrawText("[J] Clear FLAG_WINDOW_HIDDEN", 20, 220, 20, RED);
        DrawText("[T] Set FLAG_WINDOW_TOPMOST", 20, 260, 20, GREEN);
        DrawText("[Y] Clear FLAG_WINDOW_TOPMOST", 20, 290, 20, GREEN);
        DrawText("[9] SetWindowMaxSize(900, 600)", 20, 330, 20, BLUE);
        DrawText("[0] SetWindowMinSize(300, 200)", 20, 360, 20, BLUE);
        DrawText("[M] MinimizeWindow()", 420, 80, 20, VIOLET);
        DrawText("[F] ToggleFullscreen()", 420, 120, 20, BEIGE);
        DrawText("[G] ToggleBorderlessWindowed()", 420, 150, 20, BEIGE);
        DrawText("[P] SetWindowPosition(100, 100)", 420, 190, 20, MAROON);
        DrawText("[O] SetWindowOpacity(0.5f)", 420, 220, 20, MAROON);
        DrawText("[I] SetWindowIcon(red)", 420, 260, 20, DARKGREEN);
        DrawText("[U] SetWindowFocused()", 420, 290, 20, DARKGREEN);
        DrawText("[1] SetWindowMonitor(0), if available", 420, 330, 20, DARKBLUE);
        DrawText("[2] SetWindowMonitor(1), if available", 420, 360, 20, DARKBLUE);
        EndDrawing();
    }
    UnloadImage(red);
    CloseWindow();
    return 0;
}

Arguments in favor of supporting (or migrating to) Wayland:

  1. The major distros already migrated to it. And although some reverted it in the past, that's unlikely to happen again since Xwayland (more or less) has been able to hold things together for X11 support.
  2. It's usually easier to start migrating earlier (while X11 and Xwayland are actively maintained and there are no deadlines), than having to rush later if X11 or Xwayland ever get suddenly dropped.
  3. X11 is an old and large codebase that is not always easy to work with. It also was never designed to do everything we need it for these days (e.g.: forwarding).
  4. X11 will eventually (even likely) get phased out, so we may not actually have a choice on the long term.
  5. Wayland is more likely to get improvements and new features over time.

Arguments in favor of staying with X11 (or Xwayland):

  1. The distros migration to Wayland was premature. Wayland doesn't appear to be complete or stable enough for widespread usage.
  2. Although there's valid reasons for some of their architectural decisions, it causes more problems than it solves.
  3. Despite many distros pushing Wayland, they don't actually have any power. If most application devs don't want (or bother) to support Wayland, it's the distros that will end up with less software available. So Wayland will either have to give up (and return positioning control to the applications) or keep supporting Xwayland.
  4. X11 isn't perfect, but isn't broken. Don't fix what isn't broken.
  5. With Wayland giving the window manager control over positioniong, applications now depend on every window manager doing their jobs right.
  6. There are no outstanding new features on Wayland that justify the lost funcionality and amount of workaround necessary to support with it.

Conclusion:

Developers that want to support Linux now have to decide between:

  1. Implementing substancial changes to the applications operation to conform with native Wayland.
  2. Continuing to use X11 through Xwayland expecting that it will be maintained on the long term.
  3. Support both systems in parallel, despite incompatible window handling behaviors.

My two cents:

  1. Supporting (as much as possible of) Wayland would require rewriting a good part of rcore, increasing complexity and forcing unnecessary changes on other platforms that have nothing to do with this.
  2. My suggestion would be "3. Support both systems in parallel, despite incompatible window handling behaviors.". Where X11 behavior is kept as standard/default and Wayland idiosyncrasies either don't get supported at all or get just basic support.
  3. Despite being a Linux-only user myself, Linux doesn't have a large enough userbase to justify this amount of workaround.
  4. [Makefile] updated makefile to disable wayland by default #4369 is probably the way to go.
@planetis-m
Copy link
Contributor

Also raylib is broken on Wayland with fractional scaling, ie the window appears as a black rectangle with a smaller portion at the bottom displaying the contents.

@raysan5
Copy link
Owner

raysan5 commented Oct 8, 2024

@asdqwe Thank you very much for the super-detailed report about Wayland status on Linux, a really great and instructive read. Now it's easier to take a decision on this change and yeah, I agree that #4369 is the way to go for now. Thanks!

@ghost ghost closed this as completed Oct 8, 2024
Peter0x44 added a commit to Peter0x44/raylib that referenced this issue Oct 24, 2024
This is to align with the behavior of raysan5#4369, see raysan5#4371 for rationale on
disabling Wayland by default.
raysan5 pushed a commit that referenced this issue Oct 25, 2024
This is to align with the behavior of #4369, see #4371 for rationale on
disabling Wayland by default.
psxdev pushed a commit to raylib4Consoles/raylib that referenced this issue Nov 18, 2024
This is to align with the behavior of raysan5#4369, see raysan5#4371 for rationale on
disabling Wayland by default.
Qoen1 added a commit to Qoen1/raylib-cpp-group-h that referenced this issue Dec 26, 2024
* ADDED: `isGpuReady` flag, allow font loading with no GPU acceleration

* [RCORE] Update comments on fullscreen and boderless window to describe what they do (raysan5#4280)

* Update raylib_api.* by CI

* update fullscreen and borderless comments to better describe what they do.

* Update raylib_api.* by CI

---------

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* [rcore][desktop_glfw] Keeping CORE.Window.position properly in sync with glfw window position (raysan5#4190)

* WindowPosCallback added.

CORE.Window.position is now properly kept in sync with the glfw window position.

* Update rcore_desktop_glfw.c

Comments updated.

* Setting CORE.Window.position correctly in InitPlatform() as well.

This also fixes not centering the window correctly when the high dpi flag was enabled.

* Fixes centering the window in the SetWindowMonitor() function.

Here the render size has to be used again in case the high dpi flag is enabled.

* Update Window Position

Update Window Position right away in ToggleFullscreen() & ToggleBorderlessWindowed() functions

* rlgl.h: glint64 did not exist before OpenGL 3.2 (raysan5#4284)

Compilation breaks on rlgl.h for early OpenGL versions.
Glint64 did not exist on those versions (< OpenGL 3.2)

* Examples makefiles: align /usr/local with /src Makefile (raysan5#4286)

* align /usr/local with src Makefile

Align /usr/local with the /src Makefile, where it can be overriden.

* /usr/local: allow override

align /usr/local with the /src Makefile, where it can be overriden

* Update raylib.h

* ADDED: more uniform data type options raysan5#4137

* Update rlgl.h

* Update rtext.c

* [rModels] Correctly split obj meshes by material (raysan5#4285)

* Correctly split meshes from tinyobj by material so they can be represented by raylib correctly

* PR Feedback

* fix(rcore/android): Allow main() to return it its caller on configuration changes. (raysan5#4288)

* Fix missing equal sign (raysan5#4294)

I just noticed there is a missing equal sign. This PR fixes this.

* Add uConsole mapping (raysan5#4297)

* fix: In certain cases the connector status is reported UNKNOWN, should be conisdered as CONNECTED (raysan5#4305)

Co-authored-by: Michal Jaskolski <michal.jaskolski@hexagon.com>

* Fix seg fault with long comment lines (raysan5#4306)

raysan5#4304

* Change implicit conversion to explicit conversion to remove warning (raysan5#4308)

* fix vld1q_f16 undeclared in arm on stb_image_resize2.h v2.10 (raysan5#4309)

* Update BINDINGS.md (raysan5#4311)

I've updated the bindings

* fix for hardcoded index values in vboID array (raysan5#4312)

changing any of the #defines in CONFIG.H would cause issues when rendering.

* chore: GetApplicationDirectory definition for FreeBSD (raysan5#4318)

* [rtextures] add MixColors. a function to mix 2 colors together (raysan5#4310)

* added MixColors function to mix 2 colors together (Line 1428 raylib.h and Line 4995 in rtextures.c)

* renamed MixColors to ColorLerp (raysan5#4310 (comment))

* changed ColorLerp to be more like other functions

---------

Co-authored-by: CI <-ci@not-real.com>

* Update raylib_api.* by CI

* REVIEWED: `ColorLerp()` formatting raysan5#4310

* Update raylib_api.* by CI

* Update rtextures.c

* [rcore] Add filtering folders to `LoadDirectoryFilesEx()`/`ScanDirectoryFiles()` (raysan5#4302)

* Add filtering folders in ScanDirectoryFiles and ScanDirectoryFilesRecursively

Add define FILTER_FOLDER for that purpose
Fix folder names matching filter being added to result

* Move FILTER_FOLDER define to internals of rcore and document option in comment

* Update raylib_api.* by CI

* REVIEWED: `DrawTexturePro()` to avoid negative dest rec raysan5#4316

* REVIEWED: Directory filter tag raysan5#4323

* Reviewed raysan5#4323

* Update raylib.h

* Update raylib_api.* by CI

* [BINDINGS.md] Added raylib-bqn, moved rayed-bqn (raysan5#4331)

* [BINDINGS.md] Added raylib-bqn, moved rayed-bqn

rayed-bqn has had a lot of progress and I've realized it has diverged too much from raylib, and so I made raylib-bqn to be a simple binding, while rayed-bqn will be a utility wrapper.

* removed accidental newline

* [rmodels] Optional GPU skinning (raysan5#4321)

* Added optional GPU skinning

* Added skinned bone matrices support for different file formats.

* Moved new shader locations to end of enum to avoid breaking existing examples. Added gpu skinning on drawing of instanced meshes.

* Added GPU skinning example.

* Removed variable declaration to avoid shadowing warning.

* Update raylib_api.* by CI

* Some minor tweaks

* Fix rlgl standalone defaults (raysan5#4334)

* Projects: Fix CMake example project  (raysan5#4332)

* Update CMakeLists.txt

Add missing link flags

* Update README.md

Remove unneeded flag because this flag is defined in the updated CMakeList file

* Update CMakeLists.txt

* Update parser's readme to mirror fixed help text (raysan5#4336)

* Update BINDINGS.md (raysan5#4337)

Updated Lean4 bindings

* `LoadFontDefault()`: Initialize glyphs and recs to zero raysan5#4319

* ADDED: `MakeDirectory()`

* Update raylib_api.* by CI

* Update rcore.c

* Update rcore.c

* Update rcore.c

* Update rcore.c

* Update rcore.c

* Fix isGpuReady flag on android (raysan5#4340)

* [SHAPES] Add more detail to comment for DrawPixel (raysan5#4344)

* Update raylib_api.* by CI

* Add comment that draw pixel uses geometry and may be slow

* Update raylib_api.* by CI

---------

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Fix raysan5#4349

* [MODELS] Disable GPU skinning for MacOS platform (raysan5#4348)

* Update raylib_api.* by CI

* Disable GPU skinning on MacOS
Add GPU skinning example to MSVC Projects.

* Update raylib_api.* by CI

---------

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Complements the raysan5#4348 GPU skinning fix (raysan5#4352)

* Fixes GetClipboardText() memory leak for PLATFORM_DESKTOP_SDL (raysan5#4354)

* [MODELS] Better fix for GPU skinning issues (raysan5#4353)

* Make the max VBO match the animation flag.

* re-enable GPU skinning for mac, and fix the max buffer to be correct based on the GPU skinning support flag.

* [rlgl] Fix rlgl standalone defaults (raysan5#4357)

* Fix rlgl standalone defaults

* Fix rmodels

* Typo fix (raysan5#4356)

Seemed to be a typo. Hope this helps.

* Allow Zig build script to change desktop backend (raysan5#4358)

* [build] CMake: Fix GRAPHICS check (raysan5#4359)

* updated camera speeds with GetFrameTime (raysan5#4362)

* taken from FluxFlus PR (raysan5#4363)

* Fix raysan5#4355

* [example] Input virtual controls example (raysan5#4342)

* Add files via upload

* Update core_input_gamepad_virtual.c

* Add files via upload

* Update and rename core_input_gamepad_virtual.c to core_virtual_Dpad.c

* Update and rename core_virtual_Dpad.c to core_input_virtual_controls.c

* Delete examples/core/core_input_gamepad_virtual.png

* Add files via upload

* Update Makefile

* Update Makefile.Web

* Update README.md

* Update README.md

* Create core_input_virtual_controls.vcxproj

* Delete projects/VS2022/examples/core_input_virtual_controls.vcxproj

* [zig] Fix build.zig bug (raysan5#4366)

* fixed zig config.h bug

* zig fmt

* removed old comment (raysan5#4370)

* Update CHANGELOG

* updated makefile to disable wayland by default (raysan5#4369)

* Update RGFW  (raysan5#4372)

* (rcore_desktop_rgfw.c) fix errors when compiling with mingw

* define WideCharToMultiByte

* update RGFW

* move stdcall def to windows only

* fix raw cursor input

* Removed tabs and triple line-breaks

* Some update to gltf loading (raysan5#4373)

Only warns when there are more animations than currently implemented
Allows mesh indices to be unsigned char

* Fix build.zig (raysan5#4374)

* build.zig: Improve logic (raysan5#4375)

* build.zig: Fix `@src` logic

* build.zig: Clarify build error

* build.zig: Add option for enabling `raygui`

* build.zig: Expose `Options` type

* `WARNING`: REMOVED: SVG files loading and drawing, moving it to raylib-extras

* REMOVED: `LoadImageSvg()`

* Update raylib_api.* by CI

* Update BINDINGS.md (raysan5#4378)

* build.zig: Fix `@src` logic and a few things (raysan5#4380)

* REVIEWED: `CodepointToUTF8()`, clean static buffer raysan5#4379

* build.zig: Very minor fixes (raysan5#4381)

* Fix the type mismatch caused due to unsupported `?[]const u8` (raysan5#4383)

Co-authored-by: Yuval Herman <yuvalherman99@gmail.com>

* qoi: Added support for image of channels 3 (raysan5#4384)

* Fix rectangle width and height check to account for squares (raysan5#4382)

* ADDED: Utility functions: `ComputeCRC32()` and `ComputeMD5()`

* Update raylib_api.* by CI

* WARNING: BREAKING: Renamed several functions for data validation raysan5#3930

* Update raylib_api.* by CI

* Fix raysan5#4388 (raysan5#4392)

* Fix VSCode Makefile to support multiple .c files (raysan5#4391)

Updated the VSCode Makefile to allow compilation of multiple .c files instead of just one (main.c).
- Replaced `SRC` and `OBJS` definitions to dynamically include all .c and .h files in the project.
- This change enables automatic handling of any number of source files specifically in the VSCode setup.

* [rcore] added sha1 implementation (raysan5#4390)

* added sha1 implementation

* added missing part

* fixed issue

* fix to match other implementations

* Update raylib_api.* by CI

* build.zig: Clean up my mess (raysan5#4387)

* [rl_gputex] Correctly load mipmaps from DDS files (raysan5#4399)

* correction of comments (raysan5#4400)

The indication of locations for bone ids and bone weights did not correspond to their default values ​​in config.h

* build.zig: Fix various issues around `-Dconfig` (raysan5#4398)

* build.zig: Fix various issues around `-Dconfig`

* build.zig: Parse all relevant flags from `src/config.h` at comptime

* Adds MaximizeWindow() and RestoreWindow() implementation for PLATFORM_WEB (raysan5#4397)

* [rtextures] ImageDraw(): Don't try to blend images without alpha (raysan5#4395)

* removed extra update command (raysan5#4401)

* [rcore] [web] Updates `SetWindowState()` and `ClearWindowState()` to handle `FLAG_WINDOW_MAXIMIZED` for `PLATFORM_WEB` (raysan5#4402)

* Updates SetWindowState() and ClearWindowState() to handle FLAG_WINDOW_MAXIMIZED for PLATFORM_WEB

* Update MaximizeWindow() and RestoreWindow() to set/unset the FLAG_WINDOW_MAXIMIZED

* Fix MaximizeWindow() for PLATFORM_WEB (raysan5#4404)

* Adds SetWindowOpacity() implementation for PLATFORM_WEB (raysan5#4403)

* build.zig: Merge `src/build.zig` to `build.zig` (raysan5#4393)

* build.zig: Move `src/build.zig` to `build.zig`

* build.zig: Remove uses of `@src`

* build.zig: Update entry point

* [Raymath] Add C++ operator overloads for common math function (raysan5#4385)

* Update raylib_api.* by CI

* Add math operators for C++ to raymath

* better #define for disabling C++ operators

---------

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* REVIEWED: Formatting and raymath version raysan5#4385

* Updated instanced rendering support loading (raysan5#4408)

* Reviewed formatting raysan5#4408

* Removed trailing spaces

* Update raymath.h

* [Raymath] Add matrix operators to raymath for C++ (raysan5#4409)

* Add matrix operators to raymath for C++

* Fix spaces

* REVIEWED: `GetGestureHoldDuration()` comments

* Update raylib_api.* by CI

* [rcore] Adds implementation to `SetGamepadVibration()` on `PLATFORM_WEB` and updates it on `PLATFORM_DESKTOP_SDL` to handle duration (raysan5#4410)

* Updates SetGamepadVibration()

* Handle MAX_GAMEPAD_VIBRATION_TIME

* Revert low/high parameters back to left/rightMotor

* Fix missin semicolon

* Convert duration to seconds

* Add SetGamepadVibration() implementation to PLATFORM_WEB

* Update raylib_api.* by CI

* moved update out of draw area (raysan5#4413)

* REVIEWED: skinning shader for GLSL 100 raysan5#4412

* build.zig: Better specify Linux dependencies (raysan5#4406)

* Simplify EmscriptenResizeCallback() (raysan5#4415)

* build.zig: Re-add OpenGL to Linux deps (raysan5#4417)

* build.zig: Fix a minor issue with `-Dconfig` (raysan5#4418)

* Reviewed skinning shaders raysan5#4412

* Update config.h

* Update raylib.h

* Update raylib_api.* by CI

* Update core_input_gamepad example (raysan5#4416)

* [rcore] Fix raysan5#4405 (raysan5#4420)

* Fix raysan5#4405 at runtime

* Add parameter validation

* Remove default global deadzone

* [examples] Add deadzone handling to `core_input_gamepad` example (raysan5#4422)

* Add deadzone handling to core_input_gamepad example

* Rename variables

* Grammar fix in CONTRIBUTING.md (raysan5#4423)

"Can you write some tutorial/example?"
"Can you write some tutorials/examples?"

* Fix typo in rshapes.c (raysan5#4421)

* Add drawing for generic gamepad on core_input_gamepad example (raysan5#4424)

* Update skinning.fs

* Reviewed and reverted unneeded module check, `rtextures` should not depend on `rtext`

* ADDED: CHANGELOG for raylib 5.5 -WIP-

* Update CHANGELOG

* Update Makefile

* Update Makefile

* [RTEXTURES] Remove the panorama cubemap layout option (raysan5#4425)

* Remove the panorama cubemap layout, it was not implemented.
Left a todo in the code for some aspiring developer to finish.

* Update raylib_api.* by CI

---------

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>

* Update HISTORY.md

* Update CHANGELOG

* Update raylib.h

* Update raylib_api.* by CI

* Update CHANGELOG

* Update raylib.h

* Update Makefile

* Update raylib_api.* by CI

* Update raylib.h

* Update raylib_api.* by CI

* REVIEWED: GPU skninning on Web, some gotchas! raysan5#4412

* Update rlgl.h

* REVIEWED: `UpdateModelAnimationBoneMatrices()` comments

* Update raylib_api.* by CI

* Update emsdk paths to latest versions

* [rshapes] Review `DrawRectangleLines()` pixel offset (raysan5#4261)

* [rshapes] Remove `DrawRectangleLines()`'s + 1 offset

* ... and replace it with a -/+ 0.5 offset divided by current cam's zoom.

* REVIEWED: `DrawRectangleLines()`, considering view matrix for lines "alignment"

* Use free camera in model shader example (raysan5#4428)

* Add shadow map example to MSVC projects (raysan5#4430)

* Use the vertex color as part of the base shader in GLSL330 (raysan5#4431)

* Add input_virtual_controls to MSVC projects (raysan5#4433)

Fix input_virtual_controls example to use correct default font sizes

* [build] CMake: Don't build for wayland by default (raysan5#4432)

This is to align with the behavior of raysan5#4369, see raysan5#4371 for rationale on
disabling Wayland by default.

* [build] [web] Fix examples `Makefile` for `PLATFORM_WEB` (raysan5#4434)

* Fix examples Makefile for PLATFORM_WEB

* Replace shell with assignment operator

* Replace tab with spaces

* Update Makefile.Web

* REVIEWED: WebGL2 (OpenGL ES 3.0) backend flags (PLATFORM_WEB) raysan5#4330

* Minor format tweaks

* Use mingw32-make for Windows (raysan5#4436)

* [rtextures/rlgl] Load mipmaps for cubemaps (raysan5#4429)

* [rlgl] Load cubemap mipmaps

* [rtextures] Only generate mipmaps that don't already exist

* [rtextures] ImageDraw(): Implement drawing to mipmaps

* [rtextures] Load cubemap mipmaps

* Reviewed formating to follow raylib conventions raysan5#4429

* Reviewed formatting, remove end-line points, for consistency with comments

* Update cgltf.h

* Update dr_mp3.h

* Update dr_wav.h

* Update qoa.h

* Update stb_image.h

* Update stb_image_resize2.h

* Update stb_truetype.h

* Fix examples Makefile for NetBSD (raysan5#4438)

* fix makefile

* moving to LDPATHS

* fix clean and ldlibs stuff

* Update Makefile

* REVIEWED: `LoadTextureCubemap()` to avoid crash raysan5#4429

* fix (raysan5#4440)

* [rtextures] LoadTextureCubemap(): Copy image before generating mipmaps, to avoid dangling re-allocated pointers (raysan5#4439)

* Fix MSVC errors for PLATFORM_DESKTOP_RGFW (raysan5#4441)

* (rcore_desktop_rgfw.c) fix errors when compiling with mingw

* define WideCharToMultiByte

* update RGFW

* move stdcall def to windows only

* fix raw cursor input

* Fix warnings, update RGFW, fix msvc errors (make sure windows macro _WIN32 is correct)

* Fix signed/unsigned mismatch in rlgl (raysan5#4443)

* Update README.md

* Fix empty input string for MeasureTextEx (raysan5#4448)

* Fix inconsistent dll linkage warning on windows (raysan5#4447)

* Update rcore_desktop_glfw.c

* Update rtext.c

* [shapes] Add `shapes_rectangle_advanced ` example implementing a `DrawRectangleRoundedGradientH` function (raysan5#4435)

* [rshapes] Add  function

* "[shapes] rectangle advanced: fix screen width and height to fit with other examples"

* fix the issue with GetScreenWidth/GetScreenHeight that was identified on other platforms (raysan5#4451)

* Fix SetWindowSize() for PLATFORM_WEB (raysan5#4452)

* Update HISTORY.md

* Update Makefile

* Update rmodels.c - 'fix' for GenMeshSphere artifact (raysan5#4460)

When creating a new sphere mesh with high number of slices/rings the top and bottom parts of the generated sphere are removed. This happens because the triangles in those parts, due to high resolution, end up being very small and are removed as part of the 'par_shapes' library's optimization. Adding par_shapes_set_epsilon_degenerate_sphere(0.0); before generating the sphere mesh sets the threshold for removal of small triangles is removed and the sphere is returned to raylib correctly.

* Added last week commits info

* RENAMED: `UpdateModelAnimationBoneMatrices()` to `UpdateModelAnimationBones()`

Still, not fully convinced of those functions naming, despite quite descriptive, sounds a bit confusing to me...

* Update raylib_api.* by CI

* Fix for issue 4454, MatrixDecompose() gave incorrect output for certain combinations of scale and rotation (raysan5#4461)

* Update CHANGELOG

* implemented new linear gradient generation function (raysan5#4462)

* Update Makefile.Web

* Update core_2d_camera_mouse_zoom.c

* fix float casting warnings (raysan5#4471)

* UpdateModelAnimation speedup (raysan5#4470)

If we borrow from the GPU skinned animation code, we can just multiply the vertex by the matrix * weight and shave a chunk of CPU time.

* Improve cross-compilation with zig builds (raysan5#4468)

- Add xcode_frameworks when cross compiling for mac (ref:
https://github.com/hexops/mach/blob/main/build.zig)
- Add emsdk when cross compiling for wasm (ref:
https://github.com/floooh/sokol-zig/blob/master/build.zig)

Signed-off-by: Tomas Slusny <slusnucky@gmail.com>

* [rcore]  Clipboard Image Support  (raysan5#4459)

* [rcore] add 'GetClipboardImage' for windows

* [rcore] GetClipboardImage removed some unneeded defines

* [rcore] PLATFORM_SDL: create a compatility layer for SDL3

* external: add win32_clipboard.h header only lib

* [rcore] using win32_clipboard on platforms rlfw and rgfw

* [rcore] fix warnings in SDL3 compatibility layer

* Makefile: Allow specifying SDL_LIBRARIES to link, this helps with SDL3

* Makefile: examples makefile now compile others/rlgl_standalone only when TARGET_PLATFORM is PLATFORM_DESKTOP_GFLW

* Makefile: examples makefile now compile others/rlgl_standalone only when TARGET_PLATFORM is PLATFORM_DESKTOP_GFLW

* [rcore]: PLATFORM_SDL: improve clipboard data retrieval

* external: remove unused function from win32_clipboard.h

* Makefile: allow for extra flags necessary when compiling for SDL3

* [rcore]: fix string typo

* [rcore]: Properly handle NULL dpi passing. As is allowed in SDL2

* external: fix arch finding on win32_clipboard.h to allow compilation on msvc cmake CI

* [rcore]: PLATFORM_SDL: Treat monitor as an ID in SDL3 as opposed to an index as in SDL2

* [rcore]: typo

* Update raylib_api.* by CI

* build.zig: Remove addRaylib and fix raygui builds when using raylib as dep (raysan5#4475)

- addRaylib just duplicates what adding raylib as dependency already does
  so it do not needs to exist
- move raygui build to standard build process when flag is enabled. this
  works correctly when using raylib as dependency and having raygui as
  dependency as well. problem with previous approach was that raygui was in
  options but it was doing nothing because you had to also use addRaygui for
  it to be effective

Signed-off-by: Tomas Slusny <slusnucky@gmail.com>

* Improved logos size

* Fix the X axis of the second vertex of the Y negative cap of a cylinders, triangle fan (raysan5#4478)

* Fix a typecast warning in glfw clipboard access (raysan5#4479)

* [rcore]: Issue an warning instead of an error when checking SUPPORT_CLIPBOARD_IMAGE necessary support detection (raysan5#4477)

* Fix the example lighting shaders to use both frag and diffuse colors so they work with shapes and meshes. (raysan5#4482)

* Update CHANGELOG

* build.zig: remove raygui from options and re add adding raygui as a (raysan5#4485)

function

* Fix Makefile.Web (raysan5#4487)

* Update CHANGELOG

* Update HISTORY.md

* Update CHANGELOG

* Fix touch count reset (raysan5#4488)

* Update raygui.h

* Updated Notepad++ autocomplete list for raylib 5.5

* Commented code issuing warnings on w64devkit (GCC)

Tested with w64devkit/MSVC and all seem to work as expected

* Updated raylib resource data

* Update raylib.ico

* Update emsdk path on Windows to match new raylib installer package

* Fix warnings in examples (raysan5#4492)

Move shapes/shapes_rectangle_advanced to the correct folder in MSVC project
Add core_input_virtual_controls.vcxproj back into sln file

* Fix typo in BINDINGS.md (raysan5#4493)

* Fixing an OBJ loader bug that fragmented the loaded meshes (raysan5#4494)

The nextShapeEnd integer is a pointer in the OBJ data structures.
The faceVertIndex is a vertex index counter for the mesh we are
about to create. Both integers are not compatible, which causes
the code to finish the meshes too early, thus writing the OBJ data
incompletely into the target meshes.

It wasn't noticed because for the last mesh, it process all remaining
data, causing the last mesh to contain all remaining triangles.

This would have been noticed if the OBJ meshes used different textures
for each mesh.

* Update CHANGELOG

* Update HISTORY.md

* Thanks @everyone for everything 😄

* Update HISTORY.md

* Update core_basic_window.c

* Update raylib.h

* Update raylib_api.* by CI

* Update webassembly.yml

* Update HISTORY.md

* removed workflows

* merge master

---------

Signed-off-by: Tomas Slusny <slusnucky@gmail.com>
Co-authored-by: Ray <raysan5@gmail.com>
Co-authored-by: Jeffery Myers <jeffm2501@gmail.com>
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
Co-authored-by: Dave Green <34277803+SoloByte@users.noreply.github.com>
Co-authored-by: Tchan0 <61758157+Tchan0@users.noreply.github.com>
Co-authored-by: Hesham Abourgheba <hisham.abourgheba@gmail.com>
Co-authored-by: hanaxars <156359933+hanaxars@users.noreply.github.com>
Co-authored-by: carverdamien <carverdamien@gmail.com>
Co-authored-by: Michał Jaskólski <michal@jaskolski.pro>
Co-authored-by: Michal Jaskolski <michal.jaskolski@hexagon.com>
Co-authored-by: Chris Warren-Smith <cwarrensmith@gmail.com>
Co-authored-by: masnm <49545838+masnm@users.noreply.github.com>
Co-authored-by: Alex <alexandervelez7245@gmail.com>
Co-authored-by: Jett <30197659+JettMonstersGoBoom@users.noreply.github.com>
Co-authored-by: base <git@thecortexmancer.org>
Co-authored-by: SusgUY446 <129160115+SusgUY446@users.noreply.github.com>
Co-authored-by: CI <-ci@not-real.com>
Co-authored-by: foxblock <foxblock+github@gmail.com>
Co-authored-by: Brian E <72316548+Brian-ED@users.noreply.github.com>
Co-authored-by: Daniel Holden <theonlydancingbanana@hotmail.com>
Co-authored-by: Asdqwe <asdqwe@asdqwe.com>
Co-authored-by: Ridge3Dproductions <78836162+Ridge3Dproductions@users.noreply.github.com>
Co-authored-by: Daniil Kisel <56605335+KislyjKisel@users.noreply.github.com>
Co-authored-by: Menno van der Graaf <mennovandergraaf@hotmail.com>
Co-authored-by: Ashley Chekhov <70078024+FluxFlu@users.noreply.github.com>
Co-authored-by: Nikolas <nik.wipper@gmx.de>
Co-authored-by: Kacper Zybała <zyperpl@gmail.com>
Co-authored-by: Anthony Carbajal <5776225+CrackedPixel@users.noreply.github.com>
Co-authored-by: Magnus Oblerion <82583559+oblerion@users.noreply.github.com>
Co-authored-by: Visen <48253336+VisenDev@users.noreply.github.com>
Co-authored-by: Colleague Riley <colleagueRiley@gmail.com>
Co-authored-by: Harald Scheirich <hscheirich@yahoo.com>
Co-authored-by: William Culver <39485061+cedeon@users.noreply.github.com>
Co-authored-by: Sage Hane <sage@sagehane.com>
Co-authored-by: Anand Swaroop <72886192+Anut-py@users.noreply.github.com>
Co-authored-by: yuval_dev <47389924+yuval-herman@users.noreply.github.com>
Co-authored-by: Yuval Herman <yuvalherman99@gmail.com>
Co-authored-by: R-YaTian <47445484+R-YaTian@users.noreply.github.com>
Co-authored-by: Jojaby <josh.jessopsmith@gmail.com>
Co-authored-by: Alan Arrecis <arrecis@users.noreply.github.com>
Co-authored-by: Le Juez Victor <90587919+Bigfoot71@users.noreply.github.com>
Co-authored-by: Rapha <134700614+rapha-s@users.noreply.github.com>
Co-authored-by: Cypress <140924725+cypressru@users.noreply.github.com>
Co-authored-by: Franz <franztt@users.noreply.github.com>
Co-authored-by: RadsammyT <32146976+RadsammyT@users.noreply.github.com>
Co-authored-by: IcyLeave6109 <33421921+juliohq@users.noreply.github.com>
Co-authored-by: Peter0x44 <peter0x44@disroot.org>
Co-authored-by: NishiOwO <89888985+NishiOwO@users.noreply.github.com>
Co-authored-by: mpv-enjoyer <123133847+mpv-enjoyer@users.noreply.github.com>
Co-authored-by: Everton Jr. <69195288+evertonse@users.noreply.github.com>
Co-authored-by: Arche Washi <166983671+archewashi@users.noreply.github.com>
Co-authored-by: MikiZX1 <161243635+MikiZX1@users.noreply.github.com>
Co-authored-by: waveydave <dave@dscho.com>
Co-authored-by: decromo <gh@dieg.one>
Co-authored-by: Tomas Slusny <slusnucky@gmail.com>
Co-authored-by: kimierik <105240664+kimierik@users.noreply.github.com>
Co-authored-by: Oussama Teyib <oussama.teyib@gmail.com>
Co-authored-by: Eike Decker <zet23t@googlemail.com>
This issue was closed.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants