<table><tr><td style="">davidedmundson created this revision.<br />Restricted Application added a project: Plasma.<br />Restricted Application added a subscriber: plasma-devel.
</td><a style="text-decoration: none; padding: 4px 8px; margin: 0 8px 8px; float: right; color: #464C5C; font-weight: bold; border-radius: 3px; background-color: #F7F7F9; background-image: linear-gradient(to bottom,#fff,#f1f0f1); display: inline-block; border: 1px solid rgba(71,87,120,.2);" href="https://phabricator.kde.org/D5746" rel="noreferrer">View Revision</a></tr></table><br /><div><strong>REVISION SUMMARY</strong><div><p>We need to setup our attachments when the wl_surface is created.<br />
This gets recreated when a window is hidden and shown.</p>
<p>QPlatformSurfaceCreated is emitted once, when the backing store is created,<br />
not when the wl_surface is created, despite it's similar sounding name.</p>
<p>QEvent::Show is too soon, as this is before the platform gets setVisible<br />
We do however, always get an expose event. QEvent::Hide weirdly comes after<br />
the platform has done its thing.</p></div></div><br /><div><strong>TEST PLAN</strong><div><p>See attached test on Qt 5.9<br />
Still has window decos after hide/show<br />
This needs testing on Qt 5.7 before merging</p></div></div><br /><div><strong>REPOSITORY</strong><div><div>R135 Integration for Qt applications in Plasma</div></div></div><br /><div><strong>BRANCH</strong><div><div>testing</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D5746" rel="noreferrer">https://phabricator.kde.org/D5746</a></div></div><br /><div><strong>AFFECTED FILES</strong><div><div>src/platformtheme/kwaylandintegration.cpp<br />
src/platformtheme/kwaylandintegration.h<br />
tests/CMakeLists.txt<br />
tests/windowdecotest.cpp</div></div></div><br /><div><strong>To: </strong>davidedmundson, Plasma<br /><strong>Cc: </strong>plasma-devel, ZrenBot, spstarr, progwolff, lesliezhai, ali-mohamed, jensreuterberg, abetts, sebas, apol, lukas<br /></div>