mirror of
https://github.com/hyprwm/Hyprland.git
synced 2025-07-30 11:41:53 -07:00
Compare commits
10 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
4520b30d49 | ||
|
8405aa111d | ||
|
ad46257cce | ||
|
0cfbe618b5 | ||
|
7d0944acdf | ||
|
b9990468f3 | ||
|
736a8735b3 | ||
|
b54eecbd79 | ||
|
657aeb3946 | ||
|
6807430b18 |
@@ -255,4 +255,8 @@ bindl = , XF86AudioPrev, exec, playerctl previous
|
|||||||
# Example windowrule v2
|
# Example windowrule v2
|
||||||
# windowrulev2 = float,class:^(kitty)$,title:^(kitty)$
|
# windowrulev2 = float,class:^(kitty)$,title:^(kitty)$
|
||||||
|
|
||||||
windowrulev2 = suppressevent maximize, class:.* # You'll probably like this.
|
# Ignore maximize requests from apps. You'll probably like this.
|
||||||
|
windowrulev2 = suppressevent maximize, class:.*
|
||||||
|
|
||||||
|
# Fix some dragging issues with XWayland
|
||||||
|
windowrulev2 = nofocus,class:^$,title:^$,xwayland:1,floating:1,fullscreen:0,pinned:0
|
||||||
|
@@ -867,8 +867,10 @@ void CConfigManager::postConfigReload(const Hyprlang::CParseResult& result) {
|
|||||||
if (result.error && !std::any_cast<Hyprlang::INT>(m_pConfig->getConfigValue("debug:suppress_errors")))
|
if (result.error && !std::any_cast<Hyprlang::INT>(m_pConfig->getConfigValue("debug:suppress_errors")))
|
||||||
g_pHyprError->queueCreate(result.getError(), CColor(1.0, 50.0 / 255.0, 50.0 / 255.0, 1.0));
|
g_pHyprError->queueCreate(result.getError(), CColor(1.0, 50.0 / 255.0, 50.0 / 255.0, 1.0));
|
||||||
else if (std::any_cast<Hyprlang::INT>(m_pConfig->getConfigValue("autogenerated")) == 1)
|
else if (std::any_cast<Hyprlang::INT>(m_pConfig->getConfigValue("autogenerated")) == 1)
|
||||||
g_pHyprError->queueCreate("Warning: You're using an autogenerated config! (config file: " + getMainConfigPath() + " )\nSUPER+Q -> kitty\nSUPER+M -> exit Hyprland",
|
g_pHyprError->queueCreate(
|
||||||
CColor(1.0, 1.0, 70.0 / 255.0, 1.0));
|
"Warning: You're using an autogenerated config! (config file: " + getMainConfigPath() +
|
||||||
|
" )\nSUPER+Q -> kitty (if it doesn't launch, make sure it's installed or choose a different terminal in the config)\nSUPER+M -> exit Hyprland",
|
||||||
|
CColor(1.0, 1.0, 70.0 / 255.0, 1.0));
|
||||||
else if (*PENABLEEXPLICIT != prevEnabledExplicit)
|
else if (*PENABLEEXPLICIT != prevEnabledExplicit)
|
||||||
g_pHyprError->queueCreate("Warning: You changed the render:explicit_sync option, this requires you to restart Hyprland.", CColor(0.9, 0.76, 0.221, 1.0));
|
g_pHyprError->queueCreate("Warning: You changed the render:explicit_sync option, this requires you to restart Hyprland.", CColor(0.9, 0.76, 0.221, 1.0));
|
||||||
else
|
else
|
||||||
|
@@ -268,5 +268,9 @@ bindl = , XF86AudioPrev, exec, playerctl previous
|
|||||||
# Example windowrule v2
|
# Example windowrule v2
|
||||||
# windowrulev2 = float,class:^(kitty)$,title:^(kitty)$
|
# windowrulev2 = float,class:^(kitty)$,title:^(kitty)$
|
||||||
|
|
||||||
windowrulev2 = suppressevent maximize, class:.* # You'll probably like this.
|
# Ignore maximize requests from apps. You'll probably like this.
|
||||||
|
windowrulev2 = suppressevent maximize, class:.*
|
||||||
|
|
||||||
|
# Fix some dragging issues with XWayland
|
||||||
|
windowrulev2 = nofocus,class:^$,title:^$,xwayland:1,floating:1,fullscreen:0,pinned:0
|
||||||
)#";
|
)#";
|
||||||
|
@@ -178,13 +178,18 @@ void IKeyboard::updateXKBTranslationState(xkb_keymap* const keymap) {
|
|||||||
if (xkbState)
|
if (xkbState)
|
||||||
xkb_state_unref(xkbState);
|
xkb_state_unref(xkbState);
|
||||||
|
|
||||||
|
if (xkbSymState)
|
||||||
|
xkb_state_unref(xkbSymState);
|
||||||
|
|
||||||
xkbState = nullptr;
|
xkbState = nullptr;
|
||||||
xkbStaticState = nullptr;
|
xkbStaticState = nullptr;
|
||||||
|
xkbSymState = nullptr;
|
||||||
|
|
||||||
if (keymap) {
|
if (keymap) {
|
||||||
Debug::log(LOG, "Updating keyboard {:x}'s translation state from a provided keymap", (uintptr_t)this);
|
Debug::log(LOG, "Updating keyboard {:x}'s translation state from a provided keymap", (uintptr_t)this);
|
||||||
xkbStaticState = xkb_state_new(keymap);
|
xkbStaticState = xkb_state_new(keymap);
|
||||||
xkbState = xkb_state_new(keymap);
|
xkbState = xkb_state_new(keymap);
|
||||||
|
xkbSymState = xkb_state_new(keymap);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -230,6 +235,7 @@ void IKeyboard::updateXKBTranslationState(xkb_keymap* const keymap) {
|
|||||||
|
|
||||||
xkbState = xkb_state_new(KEYMAP);
|
xkbState = xkb_state_new(KEYMAP);
|
||||||
xkbStaticState = xkb_state_new(KEYMAP);
|
xkbStaticState = xkb_state_new(KEYMAP);
|
||||||
|
xkbSymState = xkb_state_new(KEYMAP);
|
||||||
|
|
||||||
xkb_keymap_unref(KEYMAP);
|
xkb_keymap_unref(KEYMAP);
|
||||||
xkb_context_unref(PCONTEXT);
|
xkb_context_unref(PCONTEXT);
|
||||||
@@ -252,6 +258,7 @@ void IKeyboard::updateXKBTranslationState(xkb_keymap* const keymap) {
|
|||||||
|
|
||||||
xkbState = xkb_state_new(NEWKEYMAP);
|
xkbState = xkb_state_new(NEWKEYMAP);
|
||||||
xkbStaticState = xkb_state_new(NEWKEYMAP);
|
xkbStaticState = xkb_state_new(NEWKEYMAP);
|
||||||
|
xkbSymState = xkb_state_new(NEWKEYMAP);
|
||||||
|
|
||||||
xkb_keymap_unref(NEWKEYMAP);
|
xkb_keymap_unref(NEWKEYMAP);
|
||||||
xkb_context_unref(PCONTEXT);
|
xkb_context_unref(PCONTEXT);
|
||||||
@@ -332,6 +339,9 @@ void IKeyboard::updateModifiers(uint32_t depressed, uint32_t latched, uint32_t l
|
|||||||
|
|
||||||
xkb_state_update_mask(xkbState, depressed, latched, locked, 0, 0, group);
|
xkb_state_update_mask(xkbState, depressed, latched, locked, 0, 0, group);
|
||||||
|
|
||||||
|
if (xkbSymState)
|
||||||
|
xkb_state_update_mask(xkbSymState, 0, 0, 0, 0, 0, group);
|
||||||
|
|
||||||
if (!updateModifiersState())
|
if (!updateModifiersState())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@@ -382,6 +392,9 @@ void IKeyboard::updateXkbStateWithKey(uint32_t xkbKey, bool pressed) {
|
|||||||
xkb_state_update_key(xkbState, xkbKey, pressed ? XKB_KEY_DOWN : XKB_KEY_UP);
|
xkb_state_update_key(xkbState, xkbKey, pressed ? XKB_KEY_DOWN : XKB_KEY_UP);
|
||||||
|
|
||||||
if (updateModifiersState()) {
|
if (updateModifiersState()) {
|
||||||
|
if (xkbSymState)
|
||||||
|
xkb_state_update_mask(xkbSymState, 0, 0, 0, 0, 0, modifiersState.group);
|
||||||
|
|
||||||
keyboardEvents.modifiers.emit(SModifiersEvent{
|
keyboardEvents.modifiers.emit(SModifiersEvent{
|
||||||
.depressed = modifiersState.depressed,
|
.depressed = modifiersState.depressed,
|
||||||
.latched = modifiersState.latched,
|
.latched = modifiersState.latched,
|
||||||
|
@@ -82,8 +82,9 @@ class IKeyboard : public IHID {
|
|||||||
bool keymapOverridden = false;
|
bool keymapOverridden = false;
|
||||||
|
|
||||||
xkb_layout_index_t activeLayout = 0;
|
xkb_layout_index_t activeLayout = 0;
|
||||||
xkb_state * xkbState = nullptr, *xkbStaticState /* Static state: never gets modifiers or layout changes sent, used for keybinds. */ = nullptr;
|
xkb_state * xkbState = nullptr, *xkbStaticState /* Static state: never gets modifiers or layout changes sent, used for keybinds. */ = nullptr,
|
||||||
xkb_keymap* xkbKeymap = nullptr;
|
*xkbSymState = nullptr /* Same as static but gets layouts */;
|
||||||
|
xkb_keymap* xkbKeymap = nullptr;
|
||||||
|
|
||||||
struct {
|
struct {
|
||||||
uint32_t depressed = 0, latched = 0, locked = 0, group = 0;
|
uint32_t depressed = 0, latched = 0, locked = 0, group = 0;
|
||||||
|
@@ -181,33 +181,34 @@ void IHyprLayout::onWindowCreatedFloating(PHLWINDOW pWindow) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool IHyprLayout::onWindowCreatedAutoGroup(PHLWINDOW pWindow) {
|
bool IHyprLayout::onWindowCreatedAutoGroup(PHLWINDOW pWindow) {
|
||||||
static auto AUTOGROUP = CConfigValue<Hyprlang::INT>("group:auto_group");
|
static auto PAUTOGROUP = CConfigValue<Hyprlang::INT>("group:auto_group");
|
||||||
if ((*AUTOGROUP || g_pInputManager->m_bWasDraggingWindow) // check if auto_group is enabled, or, if the user is manually dragging the window into the group.
|
PHLWINDOW OPENINGON = g_pCompositor->m_pLastWindow.lock() && g_pCompositor->m_pLastWindow->m_pWorkspace == pWindow->m_pWorkspace ?
|
||||||
&& g_pCompositor->m_pLastWindow.lock() // check if a focused window exists.
|
g_pCompositor->m_pLastWindow.lock() :
|
||||||
&& g_pCompositor->m_pLastWindow != pWindow // fixes a freeze when activating togglefloat to transform a floating group into a tiled group.
|
g_pCompositor->getFirstWindowOnWorkspace(pWindow->workspaceID());
|
||||||
&& g_pCompositor->m_pLastWindow->m_pWorkspace ==
|
|
||||||
pWindow
|
if ((*PAUTOGROUP || g_pInputManager->m_bWasDraggingWindow) // check if auto_group is enabled, or, if the user is manually dragging the window into the group.
|
||||||
->m_pWorkspace // fix for multimonitor: when there is a focused group in monitor 1 and monitor 2 is empty, this enables adding the first window of monitor 2 when using the mouse to focus it.
|
&& OPENINGON // check if OPENINGON exists.
|
||||||
&& g_pCompositor->m_pLastWindow->m_sGroupData.pNextWindow.lock() // check if the focused window is a group
|
&& OPENINGON != pWindow // fixes a freeze when activating togglefloat to transform a floating group into a tiled group.
|
||||||
&& pWindow->canBeGroupedInto(g_pCompositor->m_pLastWindow.lock()) // check if the new window can be grouped into the focused group
|
&& OPENINGON->m_sGroupData.pNextWindow.lock() // check if OPENINGON is a group
|
||||||
&& !g_pXWaylandManager->shouldBeFloated(pWindow)) { // don't group XWayland windows that should be floated.
|
&& pWindow->canBeGroupedInto(OPENINGON) // check if the new window can be grouped into OPENINGON
|
||||||
|
&& !g_pXWaylandManager->shouldBeFloated(pWindow)) { // don't group XWayland windows that should be floated.
|
||||||
|
|
||||||
switch (pWindow->m_bIsFloating) {
|
switch (pWindow->m_bIsFloating) {
|
||||||
case false:
|
case false:
|
||||||
if (g_pCompositor->m_pLastWindow->m_bIsFloating)
|
if (OPENINGON->m_bIsFloating)
|
||||||
pWindow->m_bIsFloating = true;
|
pWindow->m_bIsFloating = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case true:
|
case true:
|
||||||
if (!g_pCompositor->m_pLastWindow->m_bIsFloating)
|
if (!OPENINGON->m_bIsFloating)
|
||||||
pWindow->m_bIsFloating = false;
|
pWindow->m_bIsFloating = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
static auto USECURRPOS = CConfigValue<Hyprlang::INT>("group:insert_after_current");
|
static auto USECURRPOS = CConfigValue<Hyprlang::INT>("group:insert_after_current");
|
||||||
(*USECURRPOS ? g_pCompositor->m_pLastWindow : g_pCompositor->m_pLastWindow->getGroupTail())->insertWindowToGroup(pWindow);
|
(*USECURRPOS ? OPENINGON : OPENINGON->getGroupTail())->insertWindowToGroup(pWindow);
|
||||||
|
|
||||||
g_pCompositor->m_pLastWindow->setGroupCurrent(pWindow);
|
OPENINGON->setGroupCurrent(pWindow);
|
||||||
pWindow->applyGroupRules();
|
pWindow->applyGroupRules();
|
||||||
pWindow->updateWindowDecos();
|
pWindow->updateWindowDecos();
|
||||||
recalculateWindow(pWindow);
|
recalculateWindow(pWindow);
|
||||||
|
@@ -376,7 +376,7 @@ bool CKeybindManager::onKeyEvent(std::any event, SP<IKeyboard> pKeyboard) {
|
|||||||
|
|
||||||
const auto KEYCODE = e.keycode + 8; // Because to xkbcommon it's +8 from libinput
|
const auto KEYCODE = e.keycode + 8; // Because to xkbcommon it's +8 from libinput
|
||||||
|
|
||||||
const xkb_keysym_t keysym = xkb_state_key_get_one_sym(pKeyboard->resolveBindsBySym ? pKeyboard->xkbState : m_pXKBTranslationState, KEYCODE);
|
const xkb_keysym_t keysym = xkb_state_key_get_one_sym(pKeyboard->resolveBindsBySym ? pKeyboard->xkbSymState : m_pXKBTranslationState, KEYCODE);
|
||||||
const xkb_keysym_t internalKeysym = xkb_state_key_get_one_sym(pKeyboard->xkbState, KEYCODE);
|
const xkb_keysym_t internalKeysym = xkb_state_key_get_one_sym(pKeyboard->xkbState, KEYCODE);
|
||||||
|
|
||||||
if (handleInternalKeybinds(internalKeysym))
|
if (handleInternalKeybinds(internalKeysym))
|
||||||
|
@@ -657,7 +657,7 @@ Vector2D CPointerManager::closestValid(const Vector2D& pos) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void CPointerManager::damageIfSoftware() {
|
void CPointerManager::damageIfSoftware() {
|
||||||
auto b = getCursorBoxGlobal();
|
auto b = getCursorBoxGlobal().expand(4);
|
||||||
|
|
||||||
static auto PNOHW = CConfigValue<Hyprlang::INT>("cursor:no_hardware_cursors");
|
static auto PNOHW = CConfigValue<Hyprlang::INT>("cursor:no_hardware_cursors");
|
||||||
|
|
||||||
|
@@ -394,12 +394,12 @@ void CScreencopyProtocol::bindManager(wl_client* client, void* data, uint32_t ve
|
|||||||
void CScreencopyProtocol::destroyResource(CScreencopyClient* client) {
|
void CScreencopyProtocol::destroyResource(CScreencopyClient* client) {
|
||||||
std::erase_if(m_vClients, [&](const auto& other) { return other.get() == client; });
|
std::erase_if(m_vClients, [&](const auto& other) { return other.get() == client; });
|
||||||
std::erase_if(m_vFrames, [&](const auto& other) { return other->client.get() == client; });
|
std::erase_if(m_vFrames, [&](const auto& other) { return other->client.get() == client; });
|
||||||
std::erase_if(m_vFramesAwaitingWrite, [&](const auto& other) { return other->client.get() == client; });
|
std::erase_if(m_vFramesAwaitingWrite, [&](const auto& other) { return !other || other->client.get() == client; });
|
||||||
}
|
}
|
||||||
|
|
||||||
void CScreencopyProtocol::destroyResource(CScreencopyFrame* frame) {
|
void CScreencopyProtocol::destroyResource(CScreencopyFrame* frame) {
|
||||||
std::erase_if(m_vFrames, [&](const auto& other) { return other.get() == frame; });
|
std::erase_if(m_vFrames, [&](const auto& other) { return other.get() == frame; });
|
||||||
std::erase_if(m_vFramesAwaitingWrite, [&](const auto& other) { return other.get() == frame; });
|
std::erase_if(m_vFramesAwaitingWrite, [&](const auto& other) { return !other || other.get() == frame; });
|
||||||
}
|
}
|
||||||
|
|
||||||
void CScreencopyProtocol::onOutputCommit(CMonitor* pMonitor) {
|
void CScreencopyProtocol::onOutputCommit(CMonitor* pMonitor) {
|
||||||
@@ -412,8 +412,11 @@ void CScreencopyProtocol::onOutputCommit(CMonitor* pMonitor) {
|
|||||||
|
|
||||||
// share frame if correct output
|
// share frame if correct output
|
||||||
for (auto const& f : m_vFramesAwaitingWrite) {
|
for (auto const& f : m_vFramesAwaitingWrite) {
|
||||||
|
if (!f)
|
||||||
|
continue;
|
||||||
|
|
||||||
if (!f->pMonitor || !f->buffer) {
|
if (!f->pMonitor || !f->buffer) {
|
||||||
framesToRemove.push_back(f);
|
framesToRemove.emplace_back(f);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -425,10 +428,10 @@ void CScreencopyProtocol::onOutputCommit(CMonitor* pMonitor) {
|
|||||||
f->client->lastFrame.reset();
|
f->client->lastFrame.reset();
|
||||||
++f->client->frameCounter;
|
++f->client->frameCounter;
|
||||||
|
|
||||||
framesToRemove.push_back(f);
|
framesToRemove.emplace_back(f);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto const& f : framesToRemove) {
|
for (auto const& f : framesToRemove) {
|
||||||
destroyResource(f.get());
|
std::erase(m_vFramesAwaitingWrite, f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -54,7 +54,7 @@ class CScreencopyFrame {
|
|||||||
|
|
||||||
bool good();
|
bool good();
|
||||||
|
|
||||||
SP<CScreencopyFrame> self;
|
WP<CScreencopyFrame> self;
|
||||||
WP<CScreencopyClient> client;
|
WP<CScreencopyClient> client;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@@ -92,7 +92,7 @@ class CScreencopyProtocol : public IWaylandProtocol {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
std::vector<SP<CScreencopyFrame>> m_vFrames;
|
std::vector<SP<CScreencopyFrame>> m_vFrames;
|
||||||
std::vector<SP<CScreencopyFrame>> m_vFramesAwaitingWrite;
|
std::vector<WP<CScreencopyFrame>> m_vFramesAwaitingWrite;
|
||||||
std::vector<SP<CScreencopyClient>> m_vClients;
|
std::vector<SP<CScreencopyClient>> m_vClients;
|
||||||
|
|
||||||
SP<CEventLoopTimer> m_pSoftwareCursorTimer;
|
SP<CEventLoopTimer> m_pSoftwareCursorTimer;
|
||||||
|
@@ -354,12 +354,12 @@ void CToplevelExportProtocol::bindManager(wl_client* client, void* data, uint32_
|
|||||||
void CToplevelExportProtocol::destroyResource(CToplevelExportClient* client) {
|
void CToplevelExportProtocol::destroyResource(CToplevelExportClient* client) {
|
||||||
std::erase_if(m_vClients, [&](const auto& other) { return other.get() == client; });
|
std::erase_if(m_vClients, [&](const auto& other) { return other.get() == client; });
|
||||||
std::erase_if(m_vFrames, [&](const auto& other) { return other->client.get() == client; });
|
std::erase_if(m_vFrames, [&](const auto& other) { return other->client.get() == client; });
|
||||||
std::erase_if(m_vFramesAwaitingWrite, [&](const auto& other) { return other->client.get() == client; });
|
std::erase_if(m_vFramesAwaitingWrite, [&](const auto& other) { return !other || other->client.get() == client; });
|
||||||
}
|
}
|
||||||
|
|
||||||
void CToplevelExportProtocol::destroyResource(CToplevelExportFrame* frame) {
|
void CToplevelExportProtocol::destroyResource(CToplevelExportFrame* frame) {
|
||||||
std::erase_if(m_vFrames, [&](const auto& other) { return other.get() == frame; });
|
std::erase_if(m_vFrames, [&](const auto& other) { return other.get() == frame; });
|
||||||
std::erase_if(m_vFramesAwaitingWrite, [&](const auto& other) { return other.get() == frame; });
|
std::erase_if(m_vFramesAwaitingWrite, [&](const auto& other) { return !other || other.get() == frame; });
|
||||||
}
|
}
|
||||||
|
|
||||||
void CToplevelExportProtocol::onOutputCommit(CMonitor* pMonitor) {
|
void CToplevelExportProtocol::onOutputCommit(CMonitor* pMonitor) {
|
||||||
@@ -370,11 +370,17 @@ void CToplevelExportProtocol::onOutputCommit(CMonitor* pMonitor) {
|
|||||||
|
|
||||||
// share frame if correct output
|
// share frame if correct output
|
||||||
for (auto const& f : m_vFramesAwaitingWrite) {
|
for (auto const& f : m_vFramesAwaitingWrite) {
|
||||||
if (!f->pWindow || !validMapped(f->pWindow)) {
|
if (!f)
|
||||||
framesToRemove.push_back(f);
|
continue;
|
||||||
|
|
||||||
|
if (!validMapped(f->pWindow)) {
|
||||||
|
framesToRemove.emplace_back(f);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!f->pWindow)
|
||||||
|
continue;
|
||||||
|
|
||||||
const auto PWINDOW = f->pWindow;
|
const auto PWINDOW = f->pWindow;
|
||||||
|
|
||||||
if (pMonitor != g_pCompositor->getMonitorFromID(PWINDOW->m_iMonitorID))
|
if (pMonitor != g_pCompositor->getMonitorFromID(PWINDOW->m_iMonitorID))
|
||||||
@@ -394,7 +400,7 @@ void CToplevelExportProtocol::onOutputCommit(CMonitor* pMonitor) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (auto const& f : framesToRemove) {
|
for (auto const& f : framesToRemove) {
|
||||||
destroyResource(f.get());
|
std::erase(m_vFramesAwaitingWrite, f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -45,7 +45,7 @@ class CToplevelExportFrame {
|
|||||||
|
|
||||||
bool good();
|
bool good();
|
||||||
|
|
||||||
SP<CToplevelExportFrame> self;
|
WP<CToplevelExportFrame> self;
|
||||||
WP<CToplevelExportClient> client;
|
WP<CToplevelExportClient> client;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@@ -85,7 +85,7 @@ class CToplevelExportProtocol : IWaylandProtocol {
|
|||||||
private:
|
private:
|
||||||
std::vector<SP<CToplevelExportClient>> m_vClients;
|
std::vector<SP<CToplevelExportClient>> m_vClients;
|
||||||
std::vector<SP<CToplevelExportFrame>> m_vFrames;
|
std::vector<SP<CToplevelExportFrame>> m_vFrames;
|
||||||
std::vector<SP<CToplevelExportFrame>> m_vFramesAwaitingWrite;
|
std::vector<WP<CToplevelExportFrame>> m_vFramesAwaitingWrite;
|
||||||
|
|
||||||
void shareFrame(CToplevelExportFrame* frame);
|
void shareFrame(CToplevelExportFrame* frame);
|
||||||
bool copyFrameDmabuf(CToplevelExportFrame* frame, timespec* now);
|
bool copyFrameDmabuf(CToplevelExportFrame* frame, timespec* now);
|
||||||
|
@@ -51,6 +51,8 @@ void CXDGOutputProtocol::onManagerGetXDGOutput(CZxdgOutputManagerV1* mgr, uint32
|
|||||||
#endif
|
#endif
|
||||||
pXDGOutput->client = CLIENT;
|
pXDGOutput->client = CLIENT;
|
||||||
|
|
||||||
|
pXDGOutput->outputProto = OUTPUT->owner;
|
||||||
|
|
||||||
if (!pXDGOutput->resource->resource()) {
|
if (!pXDGOutput->resource->resource()) {
|
||||||
m_vXDGOutputs.pop_back();
|
m_vXDGOutputs.pop_back();
|
||||||
mgr->noMemory();
|
mgr->noMemory();
|
||||||
@@ -104,7 +106,7 @@ CXDGOutput::CXDGOutput(SP<CZxdgOutputV1> resource_, SP<CMonitor> monitor_) : mon
|
|||||||
void CXDGOutput::sendDetails() {
|
void CXDGOutput::sendDetails() {
|
||||||
static auto PXWLFORCESCALEZERO = CConfigValue<Hyprlang::INT>("xwayland:force_zero_scaling");
|
static auto PXWLFORCESCALEZERO = CConfigValue<Hyprlang::INT>("xwayland:force_zero_scaling");
|
||||||
|
|
||||||
if (!monitor)
|
if (!monitor || !outputProto || outputProto->isDefunct())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
const auto POS = isXWayland ? monitor->vecXWaylandPosition : monitor->vecPosition;
|
const auto POS = isXWayland ? monitor->vecXWaylandPosition : monitor->vecPosition;
|
||||||
|
@@ -6,6 +6,7 @@
|
|||||||
|
|
||||||
class CMonitor;
|
class CMonitor;
|
||||||
class CXDGOutputProtocol;
|
class CXDGOutputProtocol;
|
||||||
|
class CWLOutputProtocol;
|
||||||
|
|
||||||
class CXDGOutput {
|
class CXDGOutput {
|
||||||
public:
|
public:
|
||||||
@@ -16,6 +17,7 @@ class CXDGOutput {
|
|||||||
private:
|
private:
|
||||||
WP<CMonitor> monitor;
|
WP<CMonitor> monitor;
|
||||||
SP<CZxdgOutputV1> resource;
|
SP<CZxdgOutputV1> resource;
|
||||||
|
WP<CWLOutputProtocol> outputProto;
|
||||||
|
|
||||||
std::optional<Vector2D> overridePosition;
|
std::optional<Vector2D> overridePosition;
|
||||||
|
|
||||||
|
@@ -119,6 +119,9 @@ bool CWLOutputProtocol::isDefunct() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void CWLOutputProtocol::sendDone() {
|
void CWLOutputProtocol::sendDone() {
|
||||||
|
if (defunct)
|
||||||
|
return;
|
||||||
|
|
||||||
for (auto const& r : m_vOutputs) {
|
for (auto const& r : m_vOutputs) {
|
||||||
r->resource->sendDone();
|
r->resource->sendDone();
|
||||||
}
|
}
|
||||||
|
Submodule subprojects/hyprland-protocols updated: e06482e0e6...c7c3f4cd0f
Reference in New Issue
Block a user