diff options
author | Johan Klokkhammer Helsing <johan.helsing@qt.io> | 2016-04-20 10:41:20 +0200 |
---|---|---|
committer | Johan Helsing <johan.helsing@qt.io> | 2016-09-30 13:55:30 +0000 |
commit | f7896fdc6505d8c6f3b3a239884dadab034e1fb5 (patch) | |
tree | 11f73dd52db4ecf33d5289b234f72500bd3c8a91 /tests/auto/compositor/compositor/mockclient.cpp | |
parent | 863bf669ed0b8fce782c177dfcfa1702fc28196a (diff) |
C++ API and tests for the ivi-application extension
Note, this is only an implementation of the ivi-application extension,
not ivi-controller which contains layer management interfaces.
Task-number: QTBUG-53149
Change-Id: Ic5a31156de1768f846b714a9aee9bbf8a945cbbe
Reviewed-by: Paul Olav Tvete <paul.tvete@qt.io>
Diffstat (limited to 'tests/auto/compositor/compositor/mockclient.cpp')
-rw-r--r-- | tests/auto/compositor/compositor/mockclient.cpp | 29 |
1 files changed, 28 insertions, 1 deletions
diff --git a/tests/auto/compositor/compositor/mockclient.cpp b/tests/auto/compositor/compositor/mockclient.cpp index 9b6d327a9..f2fbc5de2 100644 --- a/tests/auto/compositor/compositor/mockclient.cpp +++ b/tests/auto/compositor/compositor/mockclient.cpp @@ -51,6 +51,9 @@ MockClient::MockClient() , registry(0) , wlshell(0) , xdgShell(nullptr) + , iviApplication(nullptr) + , error(0 /* means no error according to spec */) + , protocolError({0, 0, nullptr}) { if (!display) qFatal("MockClient(): wl_display_connect() failed"); @@ -117,12 +120,28 @@ void MockClient::outputScale(void *, wl_output *, int) void MockClient::readEvents() { + if (error) + return; wl_display_dispatch(display); } void MockClient::flushDisplay() { - wl_display_dispatch_pending(display); + if (error) + return; + + if (wl_display_prepare_read(display) == 0) { + wl_display_read_events(display); + } + + if (wl_display_dispatch_pending(display) < 0) { + error = wl_display_get_error(display); + if (error == EPROTO) { + protocolError.code = wl_display_get_protocol_error(display, &protocolError.interface, &protocolError.id); + return; + } + } + wl_display_flush(display); } @@ -146,6 +165,8 @@ void MockClient::handleGlobal(uint32_t id, const QByteArray &interface) wlshell = static_cast<wl_shell *>(wl_registry_bind(registry, id, &wl_shell_interface, 1)); } else if (interface == "xdg_shell") { xdgShell = static_cast<xdg_shell *>(wl_registry_bind(registry, id, &xdg_shell_interface, 1)); + } else if (interface == "ivi_application") { + iviApplication = static_cast<ivi_application *>(wl_registry_bind(registry, id, &ivi_application_interface, 1)); } else if (interface == "wl_seat") { wl_seat *s = static_cast<wl_seat *>(wl_registry_bind(registry, id, &wl_seat_interface, 1)); m_seats << new MockSeat(s); @@ -170,6 +191,12 @@ xdg_surface *MockClient::createXdgSurface(wl_surface *surface) return xdg_shell_get_xdg_surface(xdgShell, surface); } +ivi_surface *MockClient::createIviSurface(wl_surface *surface, uint iviId) +{ + flushDisplay(); + return ivi_application_surface_create(iviApplication, iviId, surface); +} + ShmBuffer::ShmBuffer(const QSize &size, wl_shm *shm) : handle(0) { |