/* * \brief Client-side GUI session interface * \author Norman Feske * \date 2006-08-23 */ /* * Copyright (C) 2006-2017 Genode Labs GmbH * * This file is part of the Genode OS framework, which is distributed * under the terms of the GNU Affero General Public License version 3. */ #ifndef _INCLUDE__GUI_SESSION__CLIENT_H_ #define _INCLUDE__GUI_SESSION__CLIENT_H_ #include #include #include namespace Gui { struct Session_client; } class Gui::Session_client : public Genode::Rpc_client { private: Genode::Attached_dataspace _command_ds; Command_buffer &_command_buffer; public: /** * Constructor */ Session_client(Genode::Region_map &rm, Session_capability session) : Rpc_client(session), _command_ds(rm, command_dataspace()), _command_buffer(*_command_ds.local_addr()) { } Framebuffer::Session_capability framebuffer_session() override { return call(); } Input::Session_capability input_session() override { return call(); } View_handle create_view(View_handle parent = View_handle()) override { return call(parent); } void destroy_view(View_handle view) override { call(view); } View_handle view_handle(View_capability view, View_handle handle = View_handle()) override { return call(view, handle); } View_capability view_capability(View_handle handle) override { return call(handle); } void release_view_handle(View_handle handle) override { call(handle); } Genode::Dataspace_capability command_dataspace() override { return call(); } void execute() override { call(); _command_buffer.reset(); } Framebuffer::Mode mode() override { return call(); } void mode_sigh(Genode::Signal_context_capability sigh) override { call(sigh); } void buffer(Framebuffer::Mode mode, bool alpha) override { call(mode, alpha); } void focus(Gui::Session_capability session) override { call(session); } void session_control(Label selector, Session_control operation) override { call(selector, operation); } /** * Enqueue command to command buffer * * The submitted command is not executed immediately. To execute a * batch of enqueued commands, the 'execute' method must be called. * Only in the corner case when there is not space left in the command * buffer, the 'execute' is called to make room in the buffer. */ template void enqueue(ARGS... args) { enqueue(Command( CMD { args... } )); } void enqueue(Command const &command) { if (_command_buffer.full()) execute(); _command_buffer.enqueue(command); } }; #endif /* _INCLUDE__GUI_SESSION__CLIENT_H_ */