2022-03-17 16:56:33 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include "../defines.hpp"
|
2025-01-11 19:05:53 +03:00
|
|
|
#include <stack>
|
2024-12-16 15:58:19 +00:00
|
|
|
#include <vector>
|
2025-01-12 16:35:10 +00:00
|
|
|
#include "../SharedDefs.hpp"
|
2025-01-17 15:21:35 +00:00
|
|
|
#include "MiscFunctions.hpp"
|
2022-03-17 18:25:16 +01:00
|
|
|
#include "WLClasses.hpp"
|
2022-03-19 13:54:24 +01:00
|
|
|
#include <array>
|
2025-01-23 21:55:41 +01:00
|
|
|
|
2023-05-09 15:01:45 +02:00
|
|
|
#include <xf86drmMode.h>
|
2023-03-24 19:23:16 +00:00
|
|
|
#include "Timer.hpp"
|
2024-06-19 16:20:06 +02:00
|
|
|
#include "math/Math.hpp"
|
2023-08-11 17:37:52 +02:00
|
|
|
#include <optional>
|
2025-02-27 00:56:11 +01:00
|
|
|
#include "../protocols/types/ColorManagement.hpp"
|
2024-04-22 18:21:03 +01:00
|
|
|
#include "signal/Signal.hpp"
|
2024-06-19 18:25:20 +02:00
|
|
|
#include "DamageRing.hpp"
|
2024-07-21 13:09:54 +02:00
|
|
|
#include <aquamarine/output/Output.hpp>
|
|
|
|
|
#include <aquamarine/allocator/Swapchain.hpp>
|
2025-01-30 12:30:12 +01:00
|
|
|
#include <hyprutils/os/FileDescriptor.hpp>
|
2024-04-22 18:21:03 +01:00
|
|
|
|
2024-04-23 00:40:03 +00:00
|
|
|
// Enum for the different types of auto directions, e.g. auto-left, auto-up.
|
2024-12-07 18:51:18 +01:00
|
|
|
enum eAutoDirs : uint8_t {
|
2024-05-24 20:56:42 +02:00
|
|
|
DIR_AUTO_NONE = 0, /* None will be treated as right. */
|
2024-04-23 00:40:03 +00:00
|
|
|
DIR_AUTO_UP,
|
|
|
|
|
DIR_AUTO_DOWN,
|
|
|
|
|
DIR_AUTO_LEFT,
|
|
|
|
|
DIR_AUTO_RIGHT
|
|
|
|
|
};
|
|
|
|
|
|
2025-03-14 02:15:18 +03:00
|
|
|
enum eCMType : uint8_t {
|
|
|
|
|
CM_AUTO = 0, // subject to change. srgb for 8bpc, wide for 10bpc if supported
|
|
|
|
|
CM_SRGB, // default, sRGB primaries
|
|
|
|
|
CM_WIDE, // wide color gamut, BT2020 primaries
|
|
|
|
|
CM_EDID, // primaries from edid (known to be inaccurate)
|
|
|
|
|
CM_HDR, // wide color gamut and HDR PQ transfer function
|
|
|
|
|
CM_HDR_EDID, // same as CM_HDR with edid primaries
|
|
|
|
|
};
|
|
|
|
|
|
2023-08-11 17:37:52 +02:00
|
|
|
struct SMonitorRule {
|
2025-03-14 02:15:18 +03:00
|
|
|
eAutoDirs autoDir = DIR_AUTO_NONE;
|
|
|
|
|
std::string name = "";
|
|
|
|
|
Vector2D resolution = Vector2D(1280, 720);
|
|
|
|
|
Vector2D offset = Vector2D(0, 0);
|
|
|
|
|
float scale = 1;
|
|
|
|
|
float refreshRate = 60; // Hz
|
|
|
|
|
bool disabled = false;
|
|
|
|
|
wl_output_transform transform = WL_OUTPUT_TRANSFORM_NORMAL;
|
|
|
|
|
std::string mirrorOf = "";
|
|
|
|
|
bool enable10bit = false;
|
|
|
|
|
eCMType cmType = CM_SRGB;
|
|
|
|
|
float sdrSaturation = 1.0f; // SDR -> HDR
|
|
|
|
|
float sdrBrightness = 1.0f; // SDR -> HDR
|
|
|
|
|
drmModeModeInfo drmMode = {};
|
2023-08-11 17:37:52 +02:00
|
|
|
std::optional<int> vrr;
|
|
|
|
|
};
|
2022-09-13 15:25:42 +02:00
|
|
|
|
2024-01-28 01:57:13 +00:00
|
|
|
class CMonitor;
|
2024-07-21 13:09:54 +02:00
|
|
|
class CSyncTimeline;
|
2025-03-20 11:39:55 +01:00
|
|
|
class CEGLSync;
|
2024-01-28 01:57:13 +00:00
|
|
|
|
|
|
|
|
class CMonitorState {
|
|
|
|
|
public:
|
|
|
|
|
CMonitorState(CMonitor* owner);
|
2025-01-30 16:07:06 +05:00
|
|
|
~CMonitorState() = default;
|
2024-01-28 01:57:13 +00:00
|
|
|
|
|
|
|
|
bool commit();
|
|
|
|
|
bool test();
|
2024-07-21 13:09:54 +02:00
|
|
|
bool updateSwapchain();
|
2024-01-28 01:57:13 +00:00
|
|
|
|
|
|
|
|
private:
|
2024-07-21 13:09:54 +02:00
|
|
|
void ensureBufferPresent();
|
|
|
|
|
|
2024-10-19 23:03:29 +01:00
|
|
|
CMonitor* m_pOwner = nullptr;
|
2024-01-28 01:57:13 +00:00
|
|
|
};
|
|
|
|
|
|
2022-07-27 12:32:00 +02:00
|
|
|
class CMonitor {
|
2022-12-16 17:17:31 +00:00
|
|
|
public:
|
2024-08-19 18:44:22 +02:00
|
|
|
CMonitor(SP<Aquamarine::IOutput> output);
|
2023-04-07 12:18:40 +01:00
|
|
|
~CMonitor();
|
|
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
Vector2D vecPosition = Vector2D(-1, -1); // means unset
|
|
|
|
|
Vector2D vecXWaylandPosition = Vector2D(-1, -1); // means unset
|
|
|
|
|
Vector2D vecSize = Vector2D(0, 0);
|
|
|
|
|
Vector2D vecPixelSize = Vector2D(0, 0);
|
|
|
|
|
Vector2D vecTransformedSize = Vector2D(0, 0);
|
|
|
|
|
|
|
|
|
|
bool primary = false;
|
2022-03-17 16:56:33 +01:00
|
|
|
|
2024-08-08 21:01:50 +02:00
|
|
|
MONITORID ID = MONITOR_INVALID;
|
2024-07-21 13:09:54 +02:00
|
|
|
PHLWORKSPACE activeWorkspace = nullptr;
|
|
|
|
|
PHLWORKSPACE activeSpecialWorkspace = nullptr;
|
|
|
|
|
float setScale = 1; // scale set by cfg
|
|
|
|
|
float scale = 1; // real scale
|
2022-03-17 16:56:33 +01:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
std::string szName = "";
|
|
|
|
|
std::string szDescription = "";
|
|
|
|
|
std::string szShortDescription = "";
|
2022-03-17 16:56:33 +01:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
Vector2D vecReservedTopLeft = Vector2D(0, 0);
|
|
|
|
|
Vector2D vecReservedBottomRight = Vector2D(0, 0);
|
2022-03-17 16:56:33 +01:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
drmModeModeInfo customDrmMode = {};
|
2023-05-09 15:01:45 +02:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
CMonitorState state;
|
|
|
|
|
CDamageRing damage;
|
2022-03-17 18:25:16 +01:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
SP<Aquamarine::IOutput> output;
|
2025-01-29 13:16:50 +00:00
|
|
|
float refreshRate = 60; // Hz
|
2024-07-21 13:09:54 +02:00
|
|
|
int forceFullFrames = 0;
|
|
|
|
|
bool scheduledRecalc = false;
|
|
|
|
|
wl_output_transform transform = WL_OUTPUT_TRANSFORM_NORMAL;
|
|
|
|
|
float xwaylandScale = 1.f;
|
2024-09-25 10:01:13 +01:00
|
|
|
Mat3x3 projMatrix;
|
2024-07-21 13:09:54 +02:00
|
|
|
std::optional<Vector2D> forceSize;
|
|
|
|
|
SP<Aquamarine::SOutputMode> currentMode;
|
|
|
|
|
SP<Aquamarine::CSwapchain> cursorSwapchain;
|
2024-08-31 08:07:52 -05:00
|
|
|
uint32_t drmFormat = DRM_FORMAT_INVALID;
|
|
|
|
|
uint32_t prevDrmFormat = DRM_FORMAT_INVALID;
|
2024-01-28 01:57:13 +00:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
bool dpmsStatus = true;
|
|
|
|
|
bool vrrActive = false; // this can be TRUE even if VRR is not active in the case that this display does not support it.
|
|
|
|
|
bool enabled10bit = false; // as above, this can be TRUE even if 10 bit failed.
|
2025-03-14 02:15:18 +03:00
|
|
|
eCMType cmType = CM_SRGB;
|
|
|
|
|
float sdrSaturation = 1.0f;
|
|
|
|
|
float sdrBrightness = 1.0f;
|
2024-07-21 13:09:54 +02:00
|
|
|
bool createdByUser = false;
|
|
|
|
|
bool isUnsafeFallback = false;
|
2024-02-14 22:05:36 +00:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
bool pendingFrame = false; // if we schedule a frame during rendering, reschedule it after
|
|
|
|
|
bool renderingActive = false;
|
2024-02-14 22:05:36 +00:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
wl_event_source* renderTimer = nullptr; // for RAT
|
|
|
|
|
bool RATScheduled = false;
|
|
|
|
|
CTimer lastPresentationTimer;
|
2024-02-14 22:05:36 +00:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
bool isBeingLeased = false;
|
2024-02-14 22:05:36 +00:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
SMonitorRule activeMonitorRule;
|
2023-08-11 17:37:52 +02:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
// explicit sync
|
syncobj: use eventfd instead of stalling fd checks (#9437)
* syncobj: cleanup and use uniqueptrs
cleanup a bit missing removals if resource not good, erasing from
containers etc. make use of unique ptrs instead. and add default
destructors.
* syncobj: rework syncobj entirerly
remove early buffer release that was breaking explicit sync, the buffer
needs to exist until the surface commit event has been emitted and draw
calls added egl sync points, move to eventfd signaling instead of
stalling sync point checks, and recommit pending commits if waiting on a
signal. add a CDRMSyncPointState helper class. move a few weak pointers
to shared pointers so they dont destruct before we need to use them.
* syncobj: queue pending states for eventfd
eventfd requires us to queue pending stats until ready and then apply to
current, and also when no ready state exist commit the client commit on
the current existing buffer, if there is one.
* syncobj: clear current buffer damage
clear current buffer damage on current buffer commits.
* syncobj: cleanup code and fix hyprlock
remove unused code, and ensure we dont commit a empty texture causing
locksession protocol and gtk4-layer-shell misbehaving.
* syncobj: ensure buffers are cleaned up
ensure the containers having the various buffers actually gets cleaned
up from their containers, incase the CSignal isnt signaled because of
expired smart pointers or just wrong order destruction because mishaps.
also move the acquire/point setting to buffer attaching. instead of on
precommit.
* syncobj: remove unused code, optimize
remove unused code and merge sync fds if fence is valid, remove manual
directscanout buffer dropping that signals release point on pageflip, it
can cause us to signal the release point while still keeping the current
buffer and rendering it yet again causing wrong things.
* syncobj: delay buffer release on non syncobj
delay buffer releases on non syncobj surfaces until next commit, and
check on async buffers if syncobj and drop and signal the release point
on backend buffer release.
* syncobj: ensure we follow protocol
ensure we follow protocol by replacing acquire/release points if they
arrive late and replace already existing ones. also remove unneded
brackets, and dont try to manual lock/release buffers when it comes to
explicit protocol. it doesnt care about buffer releases only about
acquire and release points and signaling them.
* syncobj: lets not complicate things
set points in precommit, before checking protocol errors and we catch
any pending acquire/release points arriving late.
* syncobj: move SSurfaceState to types
remove destructor resource destroying, let resources destroys them on
their events, and move SSurfaceStates to types/SurfaceState.hpp
* syncobj: actually store the merged fd
have to actually store the mergedfd to use it.
* syncobj: cleanup a bit around fences
ensure the current asynchronous buffer is actually released on pageflip
not the previous. cleanup a bit FD handling in
commitPendingAndDoExplicitSync, and reuse the in fence when syncing
surfaces.
* syncobjs: ensure fence FD doesnt leak
calling resetexplicitfence without properly ensuring the FD is closed
before will leak it, store it per monitor and let it close itself with
the CFileDescriptor class.
* syncobj: ensure buffers are actually released
buffers were never being sent released properly.
* types: Defer buffer sync releaser until unlock
* syncobj: store directscanout fence in monitor
ensure the infence fd survives the scope of attemptdirectscanout so it
doesnt close before it should have.
* syncobj: check if if acquire is expired
we might hit a race to finish on exit where the timeline just has
destructed but the buffer waiter is still pending. and such we
removeAllWaiters null dereferences.
* syncobj: code style changes
remove quack comment, change to m_foo and use a std::vector and
weakpointer in the waiter for removal instead of a std::list.
* syncobj: remove unused async buffer drop
remove unused async buffer drop, only related to directscanout and is
handled elsewhere.
---------
Co-authored-by: Lee Bousfield <ljbousfield@gmail.com>
2025-03-14 15:08:20 +01:00
|
|
|
SP<CSyncTimeline> inTimeline;
|
|
|
|
|
SP<CSyncTimeline> outTimeline;
|
|
|
|
|
Hyprutils::OS::CFileDescriptor inFence;
|
2025-03-20 11:39:55 +01:00
|
|
|
SP<CEGLSync> eglSync;
|
syncobj: use eventfd instead of stalling fd checks (#9437)
* syncobj: cleanup and use uniqueptrs
cleanup a bit missing removals if resource not good, erasing from
containers etc. make use of unique ptrs instead. and add default
destructors.
* syncobj: rework syncobj entirerly
remove early buffer release that was breaking explicit sync, the buffer
needs to exist until the surface commit event has been emitted and draw
calls added egl sync points, move to eventfd signaling instead of
stalling sync point checks, and recommit pending commits if waiting on a
signal. add a CDRMSyncPointState helper class. move a few weak pointers
to shared pointers so they dont destruct before we need to use them.
* syncobj: queue pending states for eventfd
eventfd requires us to queue pending stats until ready and then apply to
current, and also when no ready state exist commit the client commit on
the current existing buffer, if there is one.
* syncobj: clear current buffer damage
clear current buffer damage on current buffer commits.
* syncobj: cleanup code and fix hyprlock
remove unused code, and ensure we dont commit a empty texture causing
locksession protocol and gtk4-layer-shell misbehaving.
* syncobj: ensure buffers are cleaned up
ensure the containers having the various buffers actually gets cleaned
up from their containers, incase the CSignal isnt signaled because of
expired smart pointers or just wrong order destruction because mishaps.
also move the acquire/point setting to buffer attaching. instead of on
precommit.
* syncobj: remove unused code, optimize
remove unused code and merge sync fds if fence is valid, remove manual
directscanout buffer dropping that signals release point on pageflip, it
can cause us to signal the release point while still keeping the current
buffer and rendering it yet again causing wrong things.
* syncobj: delay buffer release on non syncobj
delay buffer releases on non syncobj surfaces until next commit, and
check on async buffers if syncobj and drop and signal the release point
on backend buffer release.
* syncobj: ensure we follow protocol
ensure we follow protocol by replacing acquire/release points if they
arrive late and replace already existing ones. also remove unneded
brackets, and dont try to manual lock/release buffers when it comes to
explicit protocol. it doesnt care about buffer releases only about
acquire and release points and signaling them.
* syncobj: lets not complicate things
set points in precommit, before checking protocol errors and we catch
any pending acquire/release points arriving late.
* syncobj: move SSurfaceState to types
remove destructor resource destroying, let resources destroys them on
their events, and move SSurfaceStates to types/SurfaceState.hpp
* syncobj: actually store the merged fd
have to actually store the mergedfd to use it.
* syncobj: cleanup a bit around fences
ensure the current asynchronous buffer is actually released on pageflip
not the previous. cleanup a bit FD handling in
commitPendingAndDoExplicitSync, and reuse the in fence when syncing
surfaces.
* syncobjs: ensure fence FD doesnt leak
calling resetexplicitfence without properly ensuring the FD is closed
before will leak it, store it per monitor and let it close itself with
the CFileDescriptor class.
* syncobj: ensure buffers are actually released
buffers were never being sent released properly.
* types: Defer buffer sync releaser until unlock
* syncobj: store directscanout fence in monitor
ensure the infence fd survives the scope of attemptdirectscanout so it
doesnt close before it should have.
* syncobj: check if if acquire is expired
we might hit a race to finish on exit where the timeline just has
destructed but the buffer waiter is still pending. and such we
removeAllWaiters null dereferences.
* syncobj: code style changes
remove quack comment, change to m_foo and use a std::vector and
weakpointer in the waiter for removal instead of a std::list.
* syncobj: remove unused async buffer drop
remove unused async buffer drop, only related to directscanout and is
handled elsewhere.
---------
Co-authored-by: Lee Bousfield <ljbousfield@gmail.com>
2025-03-14 15:08:20 +01:00
|
|
|
uint64_t commitSeq = 0;
|
2024-07-21 13:09:54 +02:00
|
|
|
|
syncobj: use eventfd instead of stalling fd checks (#9437)
* syncobj: cleanup and use uniqueptrs
cleanup a bit missing removals if resource not good, erasing from
containers etc. make use of unique ptrs instead. and add default
destructors.
* syncobj: rework syncobj entirerly
remove early buffer release that was breaking explicit sync, the buffer
needs to exist until the surface commit event has been emitted and draw
calls added egl sync points, move to eventfd signaling instead of
stalling sync point checks, and recommit pending commits if waiting on a
signal. add a CDRMSyncPointState helper class. move a few weak pointers
to shared pointers so they dont destruct before we need to use them.
* syncobj: queue pending states for eventfd
eventfd requires us to queue pending stats until ready and then apply to
current, and also when no ready state exist commit the client commit on
the current existing buffer, if there is one.
* syncobj: clear current buffer damage
clear current buffer damage on current buffer commits.
* syncobj: cleanup code and fix hyprlock
remove unused code, and ensure we dont commit a empty texture causing
locksession protocol and gtk4-layer-shell misbehaving.
* syncobj: ensure buffers are cleaned up
ensure the containers having the various buffers actually gets cleaned
up from their containers, incase the CSignal isnt signaled because of
expired smart pointers or just wrong order destruction because mishaps.
also move the acquire/point setting to buffer attaching. instead of on
precommit.
* syncobj: remove unused code, optimize
remove unused code and merge sync fds if fence is valid, remove manual
directscanout buffer dropping that signals release point on pageflip, it
can cause us to signal the release point while still keeping the current
buffer and rendering it yet again causing wrong things.
* syncobj: delay buffer release on non syncobj
delay buffer releases on non syncobj surfaces until next commit, and
check on async buffers if syncobj and drop and signal the release point
on backend buffer release.
* syncobj: ensure we follow protocol
ensure we follow protocol by replacing acquire/release points if they
arrive late and replace already existing ones. also remove unneded
brackets, and dont try to manual lock/release buffers when it comes to
explicit protocol. it doesnt care about buffer releases only about
acquire and release points and signaling them.
* syncobj: lets not complicate things
set points in precommit, before checking protocol errors and we catch
any pending acquire/release points arriving late.
* syncobj: move SSurfaceState to types
remove destructor resource destroying, let resources destroys them on
their events, and move SSurfaceStates to types/SurfaceState.hpp
* syncobj: actually store the merged fd
have to actually store the mergedfd to use it.
* syncobj: cleanup a bit around fences
ensure the current asynchronous buffer is actually released on pageflip
not the previous. cleanup a bit FD handling in
commitPendingAndDoExplicitSync, and reuse the in fence when syncing
surfaces.
* syncobjs: ensure fence FD doesnt leak
calling resetexplicitfence without properly ensuring the FD is closed
before will leak it, store it per monitor and let it close itself with
the CFileDescriptor class.
* syncobj: ensure buffers are actually released
buffers were never being sent released properly.
* types: Defer buffer sync releaser until unlock
* syncobj: store directscanout fence in monitor
ensure the infence fd survives the scope of attemptdirectscanout so it
doesnt close before it should have.
* syncobj: check if if acquire is expired
we might hit a race to finish on exit where the timeline just has
destructed but the buffer waiter is still pending. and such we
removeAllWaiters null dereferences.
* syncobj: code style changes
remove quack comment, change to m_foo and use a std::vector and
weakpointer in the waiter for removal instead of a std::list.
* syncobj: remove unused async buffer drop
remove unused async buffer drop, only related to directscanout and is
handled elsewhere.
---------
Co-authored-by: Lee Bousfield <ljbousfield@gmail.com>
2025-03-14 15:08:20 +01:00
|
|
|
PHLMONITORREF self;
|
2024-05-05 22:18:10 +01:00
|
|
|
|
2022-09-13 15:25:42 +02:00
|
|
|
// mirroring
|
2024-10-19 23:03:29 +01:00
|
|
|
PHLMONITORREF pMirrorOf;
|
|
|
|
|
std::vector<PHLMONITORREF> mirrors;
|
2022-09-13 15:25:42 +02:00
|
|
|
|
2024-10-08 16:59:15 +01:00
|
|
|
// ctm
|
|
|
|
|
Mat3x3 ctm = Mat3x3::identity();
|
|
|
|
|
bool ctmUpdated = false;
|
|
|
|
|
|
2023-09-28 21:48:33 +01:00
|
|
|
// for tearing
|
2024-04-27 12:43:12 +01:00
|
|
|
PHLWINDOWREF solitaryClient;
|
2023-09-30 17:07:50 +01:00
|
|
|
|
2024-07-21 13:09:54 +02:00
|
|
|
// for direct scanout
|
|
|
|
|
PHLWINDOWREF lastScanout;
|
2025-03-17 16:06:41 -05:00
|
|
|
bool scanoutNeedsCursorUpdate = false;
|
2024-07-21 13:09:54 +02:00
|
|
|
|
2023-09-30 17:07:50 +01:00
|
|
|
struct {
|
|
|
|
|
bool canTear = false;
|
|
|
|
|
bool nextRenderTorn = false;
|
|
|
|
|
bool activelyTearing = false;
|
|
|
|
|
|
|
|
|
|
bool busy = false;
|
|
|
|
|
bool frameScheduledWhileBusy = false;
|
|
|
|
|
} tearingState;
|
2023-09-28 21:48:33 +01:00
|
|
|
|
2024-04-22 18:21:03 +01:00
|
|
|
struct {
|
|
|
|
|
CSignal destroy;
|
|
|
|
|
CSignal connect;
|
|
|
|
|
CSignal disconnect;
|
2024-04-29 01:28:26 +01:00
|
|
|
CSignal dpmsChanged;
|
|
|
|
|
CSignal modeChanged;
|
2024-04-22 18:21:03 +01:00
|
|
|
} events;
|
|
|
|
|
|
2024-05-09 21:47:21 +01:00
|
|
|
std::array<std::vector<PHLLSREF>, 4> m_aLayerSurfaceLayers;
|
2022-03-17 18:25:16 +01:00
|
|
|
|
2022-07-27 12:32:00 +02:00
|
|
|
// methods
|
2025-02-26 17:56:37 +03:00
|
|
|
void onConnect(bool noRule);
|
|
|
|
|
void onDisconnect(bool destroy = false);
|
|
|
|
|
bool applyMonitorRule(SMonitorRule* pMonitorRule, bool force = false);
|
|
|
|
|
void addDamage(const pixman_region32_t* rg);
|
|
|
|
|
void addDamage(const CRegion& rg);
|
|
|
|
|
void addDamage(const CBox& box);
|
|
|
|
|
bool shouldSkipScheduleFrameOnMouseEvent();
|
|
|
|
|
void setMirror(const std::string&);
|
|
|
|
|
bool isMirror();
|
|
|
|
|
bool matchesStaticSelector(const std::string& selector) const;
|
|
|
|
|
float getDefaultScale();
|
|
|
|
|
void changeWorkspace(const PHLWORKSPACE& pWorkspace, bool internal = false, bool noMouseMove = false, bool noFocus = false);
|
|
|
|
|
void changeWorkspace(const WORKSPACEID& id, bool internal = false, bool noMouseMove = false, bool noFocus = false);
|
|
|
|
|
void setSpecialWorkspace(const PHLWORKSPACE& pWorkspace);
|
|
|
|
|
void setSpecialWorkspace(const WORKSPACEID& id);
|
|
|
|
|
void moveTo(const Vector2D& pos);
|
|
|
|
|
Vector2D middle();
|
|
|
|
|
void updateMatrix();
|
|
|
|
|
WORKSPACEID activeWorkspaceID();
|
|
|
|
|
WORKSPACEID activeSpecialWorkspaceID();
|
|
|
|
|
CBox logicalBox();
|
|
|
|
|
void scheduleDone();
|
|
|
|
|
bool attemptDirectScanout();
|
|
|
|
|
void setCTM(const Mat3x3& ctm);
|
|
|
|
|
void onCursorMovedOnMonitor();
|
|
|
|
|
|
|
|
|
|
void debugLastPresentation(const std::string& message);
|
|
|
|
|
void onMonitorFrame();
|
|
|
|
|
|
|
|
|
|
bool m_bEnabled = false;
|
|
|
|
|
bool m_bRenderingInitPassed = false;
|
|
|
|
|
WP<CWindow> m_previousFSWindow;
|
|
|
|
|
NColorManagement::SImageDescription imageDescription;
|
2022-07-27 12:32:00 +02:00
|
|
|
|
2022-03-18 22:35:51 +01:00
|
|
|
// For the list lookup
|
|
|
|
|
|
2022-07-27 12:32:00 +02:00
|
|
|
bool operator==(const CMonitor& rhs) {
|
2022-03-18 22:35:51 +01:00
|
|
|
return vecPosition == rhs.vecPosition && vecSize == rhs.vecSize && szName == rhs.szName;
|
|
|
|
|
}
|
2022-09-13 15:25:42 +02:00
|
|
|
|
2025-01-11 19:05:53 +03:00
|
|
|
// workspace previous per monitor functionality
|
|
|
|
|
SWorkspaceIDName getPrevWorkspaceIDName(const WORKSPACEID id);
|
|
|
|
|
void addPrevWorkspaceID(const WORKSPACEID id);
|
|
|
|
|
|
2022-12-16 17:17:31 +00:00
|
|
|
private:
|
2025-01-11 19:05:53 +03:00
|
|
|
void setupDefaultWS(const SMonitorRule&);
|
|
|
|
|
WORKSPACEID findAvailableDefaultWS();
|
2024-07-21 13:09:54 +02:00
|
|
|
|
2025-01-11 19:05:53 +03:00
|
|
|
bool doneScheduled = false;
|
|
|
|
|
std::stack<WORKSPACEID> prevWorkSpaces;
|
2024-07-21 13:09:54 +02:00
|
|
|
|
|
|
|
|
struct {
|
|
|
|
|
CHyprSignalListener frame;
|
|
|
|
|
CHyprSignalListener destroy;
|
|
|
|
|
CHyprSignalListener state;
|
|
|
|
|
CHyprSignalListener needsFrame;
|
|
|
|
|
CHyprSignalListener presented;
|
|
|
|
|
CHyprSignalListener commit;
|
|
|
|
|
} listeners;
|
2022-09-25 20:07:48 +02:00
|
|
|
};
|